*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:#fff7ed;color:#3b2f2f}button,input{font:inherit}.h5-shell{min-height:100vh;background:radial-gradient(circle at top,#fff7d6 0,#fff4ec 35%,#ffe4e6);padding-bottom:34px}.mobile-header{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:#ffffffb8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.7)}.mobile-header b{display:block;font-size:18px}.mobile-header span{font-size:12px;color:#9a6b46}.auth-card,.page{width:min(560px,94vw);margin:22px auto}.auth-card{background:#fff;border-radius:30px;padding:24px;box-shadow:0 22px 70px #b4530924;border:1px solid #ffedd5}.auth-hero{text-align:center}.coin{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#f97316,#ef4444);display:grid;place-items:center;color:#fff;font-weight:900;font-size:28px;margin:0 auto 12px;box-shadow:0 12px 30px #ef444440}.coin.big{width:82px;height:82px;font-size:38px}.auth-hero h1{margin:0}.auth-hero p,.tips,.empty{color:#9a6b46;font-size:13px}.switch{display:grid;grid-template-columns:1fr 1fr;background:#fff7ed;padding:5px;border-radius:18px;margin:20px 0}.switch button{border:0;background:transparent;border-radius:14px;padding:11px;color:#9a6b46}.switch button.active{background:#fff;color:#ea580c;font-weight:800;box-shadow:0 8px 20px #ea580c1f}.input{width:100%;height:48px;border:1px solid #fed7aa;border-radius:16px;background:#fffaf5;padding:0 14px;margin:8px 0;outline:none}.input:focus{border-color:#fb923c;box-shadow:0 0 0 4px #fb923c26}.sms-row{display:grid;grid-template-columns:1fr 118px;gap:8px}.primary-btn,.outline-btn,.mini-btn{border:0;border-radius:16px;padding:12px 16px;cursor:pointer}.primary-btn{width:100%;background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;font-weight:900;box-shadow:0 12px 28px #ef444438;margin-top:10px}.primary-btn:disabled{opacity:.6}.outline-btn{background:#fff;border:1px solid #fed7aa;color:#c2410c;font-weight:700}.mini-btn{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;padding:8px 12px}.user-banner{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#fffbeb,#fff);border:1px solid #ffedd5;border-radius:26px;padding:18px;margin-bottom:16px;box-shadow:0 16px 50px #b453091a}.user-banner span{display:block;color:#9a6b46}.user-banner b{font-size:22px}.avatar{width:54px;height:54px;border-radius:19px;background:linear-gradient(135deg,#fb923c,#f43f5e);display:grid;place-items:center;color:#fff;font-weight:900;font-size:22px}.project-list,.wins-list{display:grid;gap:16px}.project-card,.win-card,.wheel-card,.tool-card{background:#fff;border:1px solid #ffedd5;border-radius:26px;overflow:hidden;box-shadow:0 16px 48px #b453091a}.project-card{cursor:pointer}.cover{height:150px;background:linear-gradient(135deg,#fef3c7,#fed7aa);background-size:cover;background-position:center;position:relative}.cover span{position:absolute;left:14px;top:14px;background:#ffffffe6;color:#ea580c;border-radius:999px;padding:6px 12px;font-weight:800;font-size:12px}.project-body{padding:18px}.project-body h3{margin:0 0 8px}.project-body p{color:#9a6b46;font-size:13px}.back{border:0;background:transparent;color:#c2410c;font-weight:800;margin:0 0 12px}.draw-title{text-align:center;margin:10px 0 16px}.draw-title h2{margin:0;font-size:28px}.draw-title p{color:#9a6b46}.draw-title b{font-size:28px;color:#ef4444}.wheel-card{position:relative;padding:54px 14px 30px;display:grid;place-items:center;overflow:visible;min-height:410px}.wheel{--wheel-size:min(328px, calc(100vw - 78px) );--slot-radius:calc(var(--wheel-size) * -.345);width:var(--wheel-size);height:var(--wheel-size);border-radius:50%;position:relative;border:13px solid #fff;box-shadow:inset 0 0 0 3px #fb923c,0 24px 58px #ef444433,0 0 0 1px #fb923c1f;transition-property:transform;transition-timing-function:cubic-bezier(.08,.76,.06,1);will-change:transform;overflow:hidden}.wheel:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:repeating-conic-gradient(from -20deg,#ffffff6b,#ffffff6b 1deg,#fff0 1deg,#fff0 40deg);z-index:1;pointer-events:none}.wheel:after{content:"";position:absolute;inset:calc(var(--wheel-size) * .345);border-radius:50%;background:radial-gradient(circle,#fffaf2 0,#fff4df 70%,#ffe0bd);box-shadow:0 0 0 1px #fb923c4d,inset 0 8px 18px #ffffffdb;z-index:2;pointer-events:none}.wheel-slot{position:absolute;left:50%;top:50%;z-index:3;width:74px;min-height:74px;text-align:center;color:#7c2d12;display:grid;place-items:center;gap:4px;transform-origin:center;pointer-events:none}.wheel-slot b{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:82px;line-height:1.12;font-size:clamp(11px,3vw,15px);font-weight:900;text-shadow:0 1px 0 rgba(255,255,255,.72);word-break:break-all}.wheel-slot.active .prize-thumb{box-shadow:0 0 0 3px #ef44442e,0 10px 20px #ef444440}.wheel-slot.placeholder{opacity:.92}.prize-thumb{width:42px;height:42px;border-radius:14px;background:#ffffffe0;display:grid;place-items:center;margin:0 auto 2px;box-shadow:0 8px 18px #7c2d121a;border:1px solid rgba(255,255,255,.9);overflow:hidden}.prize-thumb img{width:100%;height:100%;object-fit:cover;display:block}.prize-thumb span{font-size:18px;font-weight:900;color:#c2410c}.pointer{position:absolute;top:35px;left:50%;transform:translate(-50%);z-index:7;width:0;height:0;border-left:17px solid transparent;border-right:17px solid transparent;border-top:36px solid #ef4444;filter:drop-shadow(0 4px 0 rgba(255,255,255,.8)) drop-shadow(0 7px 8px rgba(124,45,18,.22))}.pointer:after{content:"";position:absolute;left:-8px;top:-34px;width:16px;height:16px;border-radius:50%;background:#fff}.draw-btn{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:6;width:112px;height:112px;border-radius:50%;border:0;background:linear-gradient(135deg,#ef4444,#f97316);color:#fff;font-size:23px;font-weight:900;box-shadow:0 12px 34px #ef444457,inset 0 4px 8px #ffffff47;cursor:pointer}.draw-btn:disabled{opacity:.72;cursor:not-allowed}.wheel-rule-tip{text-align:center;margin:10px auto 0;color:#9a6b46;font-size:12px}.tool-card{display:grid;grid-template-columns:1fr;gap:10px;padding:16px;margin-top:16px}.win-card{display:grid;grid-template-columns:82px 1fr;gap:14px;padding:14px}.win-card img{width:82px;height:82px;border-radius:20px;object-fit:cover;background:#fff7ed}.win-card h3{margin:2px 0 6px}.win-card p{margin:3px 0;color:#9a6b46;font-size:13px}.win-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.empty{text-align:center;background:#fff;border:1px dashed #fdba74;border-radius:22px;padding:30px}.toast{position:fixed;left:50%;top:20px;transform:translate(-50%);background:#431407;color:#fff;border-radius:999px;padding:10px 16px;box-shadow:0 16px 40px #43140738;z-index:20}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#4314076b;display:grid;place-items:center;z-index:30;padding:18px}.modal-card{width:min(430px,94vw);background:#fff;border-radius:26px;padding:18px;box-shadow:0 24px 80px #43140747}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.modal-head h3{margin:0}.modal-head button{border:0;background:#fff7ed;border-radius:12px;width:34px;height:34px;font-size:22px;color:#c2410c}.result-box{text-align:center}.result-box h2{margin:10px 0}.form label{display:block;color:#7c2d12;font-weight:800}.result-box code,.qr-token{display:block;background:#fff7ed;border:1px solid #fed7aa;border-radius:14px;padding:14px;margin:12px 0;color:#7c2d12;word-break:break-all}@media (min-width:680px){.tool-card{grid-template-columns:repeat(3,1fr)}}@media (max-width:380px){.wheel-card{min-height:382px;padding-top:48px}.draw-btn{width:100px;height:100px;font-size:20px}.wheel-slot{width:66px}.prize-thumb{width:36px;height:36px}.wheel-slot b{font-size:11px}.pointer{top:32px}}.captcha-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#43140785;display:grid;place-items:center;z-index:80;padding:18px}.captcha-card{width:min(430px,94vw);background:#fff;border-radius:26px;padding:18px;box-shadow:0 24px 90px #43140757;border:1px solid #ffedd5}.captcha-desc{margin:0 0 14px;color:#9a6b46;font-size:14px;line-height:1.7}.aliyun-captcha-element{min-height:1px}.captcha-trigger{margin-top:10px}.captcha-status{min-height:22px;margin:12px 0 0;font-size:13px;color:#9a6b46;text-align:center}.captcha-status.error{color:#dc2626}.captcha-status.success{color:#16a34a}.captcha-status.loading,.captcha-status.verifying{color:#ea580c}
