:root{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;color:#17201b;background:#edf5ef}*{box-sizing:border-box}body{margin:0}.pay-page{min-height:100vh;max-width:480px;margin:0 auto;padding:calc(env(safe-area-inset-top) + 18px) 18px calc(env(safe-area-inset-bottom) + 20px);background:radial-gradient(circle at 84% 8%,rgba(255,221,128,.42),transparent 28%),linear-gradient(180deg,#f4fff7,#fff,#edf8f0)}.official-head{display:flex;align-items:center;gap:12px;color:#073c22}.official-head svg{color:#07c160}.official-head div{display:grid;gap:3px}.official-head strong{font-size:21px}.official-head span{color:#66766c;font-size:13px}.pay-card,.qr-panel{margin-top:22px;padding:20px;border:1px solid #dcebe0;border-radius:22px;background:#ffffffeb;box-shadow:0 18px 44px #1b5f371f}.merchant,.amount{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.merchant span,.amount span{color:#75847b}.merchant strong{font-size:14px}.amount strong{color:#d88712;font-size:32px}.security-row{margin-top:12px;padding:12px;border-radius:14px;color:#23603c;background:#edfff4;display:flex;align-items:center;gap:8px;font-size:13px}.security-row.paid{color:#056338;background:#e5fff0}.qr-panel{text-align:center}.qr-box{width:190px;height:190px;margin:0 auto 18px;border:10px solid #f3faf5;border-radius:22px;background:#fff;display:grid;place-items:center;color:#17201b}.qr-panel h1{margin:0;font-size:22px}.qr-panel p{margin:10px auto 0;max-width:310px;color:#79877e;font-size:12px;word-break:break-all}.pay-button{width:100%;height:54px;margin-top:20px;border:0;border-radius:999px;color:#fff;background:#07c160;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:17px;font-weight:900;box-shadow:0 14px 32px #07c16052}.pay-button:disabled{opacity:.72}.spin{animation:spin .9s linear infinite}.pay-loading,.pay-error,.paid-state{min-height:210px;display:grid;place-items:center;align-content:center;gap:12px;color:#627168}.pay-error strong,.paid-state h1{margin:0;color:#17201b;font-size:20px}.pay-error span,.paid-state p{margin:0;color:#79877e;font-size:13px}.pay-error button{height:38px;padding:0 16px;border:0;border-radius:999px;color:#fff;background:#07c160;display:inline-flex;align-items:center;gap:7px;font-weight:800}.paid-state svg{color:#07c160}.pay-inline-error{margin-top:12px;padding:12px 14px;border-radius:14px;color:#9f2a1f;background:#fff1f1;font-size:13px;line-height:1.5}footer{margin-top:18px;color:#839087;text-align:center;font-size:12px}.wechat-page{min-height:100vh;max-width:480px;margin:0 auto;padding:calc(env(safe-area-inset-top) + 28px) 24px calc(env(safe-area-inset-bottom) + 24px);color:#111;background:#f7f7f7}.wechat-title{display:grid;justify-items:center;gap:10px;padding-top:26px}.wechat-title span{font-size:17px;font-weight:700}.wechat-title small{color:#888;font-size:12px}.wechat-amount{margin-top:32px;text-align:center;color:#111;font-size:46px;font-weight:600;letter-spacing:0}.wechat-info{margin-top:34px;border-top:1px solid #e5e5e5;border-bottom:1px solid #e5e5e5;background:#fff}.wechat-info div{min-height:52px;padding:0 4px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #eeeeee}.wechat-info div:last-child{border-bottom:0}.wechat-info span{color:#777;font-size:15px}.wechat-info strong{color:#222;font-size:15px;font-weight:500}.wechat-pay-btn{width:100%;height:48px;margin-top:34px;border:0;border-radius:5px;color:#fff;background:#07c160;font-size:17px;font-weight:700}.wechat-pay-btn:disabled{opacity:.72}.wechat-safe{position:fixed;left:0;right:0;bottom:calc(env(safe-area-inset-bottom) + 18px);color:#9a9a9a;text-align:center;font-size:12px}.wechat-loading,.wechat-error,.wechat-paid{min-height:70vh;display:grid;place-items:center;align-content:center;gap:12px;color:#777}.wechat-error strong,.wechat-paid strong{color:#111;font-size:20px}.wechat-error button{height:38px;padding:0 18px;border:0;border-radius:5px;color:#fff;background:#07c160}.wechat-paid svg{color:#07c160}.wechat-inline-error{margin-top:14px;padding:12px;border-radius:5px;color:#9f2a1f;background:#fff0f0;font-size:13px;line-height:1.5}@keyframes spin{to{transform:rotate(360deg)}}
