:root{color:#14202e;font-family:Inter,PingFang SC,Microsoft YaHei,Arial,sans-serif;background:#eaf1f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{border:0;cursor:pointer}.app-shell{min-height:100vh;display:flex;justify-content:center;padding:max(10px,env(safe-area-inset-top)) 10px max(14px,env(safe-area-inset-bottom));background:radial-gradient(circle at top left,rgba(39,156,235,.18),transparent 34%),linear-gradient(180deg,#f7fbff,#e6eef3)}.login-panel,.recharge-page{width:min(100%,430px)}.login-panel{align-self:center;padding:22px 18px 18px;border:1px solid rgba(117,143,163,.2);border-radius:8px;background:#ffffffe0;box-shadow:0 24px 60px #1e3d5229}.brand-icon{display:block;width:76px;height:76px;object-fit:cover;border-radius:20px;margin:0 auto 12px;box-shadow:0 16px 32px #1475c038}.login-heading{text-align:center;margin-bottom:18px}.login-heading p{margin:0 0 6px;color:#4b7f9c;font-size:14px;font-weight:700}.login-heading h1{margin:0;font-size:24px;line-height:1.18}.login-form,.panel{display:grid;gap:12px}.login-form label,.custom-input,.remember-row{display:grid;gap:8px}.login-form span,.custom-input span{color:#657789;font-size:14px;font-weight:700}.login-form input,.custom-input input{width:100%;min-height:44px;border:1px solid #d6e1e8;border-radius:8px;padding:0 14px;background:#f8fbfd;color:#14202e;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.login-form input:focus,.custom-input input:focus,.custom-input.active input{border-color:#2498e3;background:#fff;box-shadow:0 0 0 4px #2498e31f}.form-error{min-height:20px;color:#d9464f;font-size:14px}.remember-row{display:flex;grid-template-columns:none;align-items:center;gap:8px}.remember-row input{width:18px;height:18px;min-height:0;accent-color:#1598e6}.primary-button{min-height:46px;border-radius:8px;background:linear-gradient(135deg,#1598e6,#25b6c8);color:#fff;font-size:17px;font-weight:800;box-shadow:0 14px 28px #1a90cf3d}.primary-button:active{transform:translateY(1px)}.primary-button:disabled{cursor:not-allowed;opacity:.72;transform:none}.recharge-page{display:grid;gap:14px}.account-card,.panel{border:1px solid rgba(117,143,163,.18);border-radius:8px;background:#ffffffe6;box-shadow:0 16px 38px #2a45571a}.account-card{position:relative;overflow:hidden;display:grid;gap:18px;padding:22px 18px 20px}.account-topline,.account-copy,.balance-row,.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.account-copy,.account-topline{padding-right:96px}.account-topline .account-copy{min-width:0;padding-right:0;display:grid;justify-content:start;gap:4px}.account-copy span,.balance-row span,.section-title span{color:#6a7c8b;font-size:14px;font-weight:700}.account-copy strong{max-width:100%;overflow:hidden;color:#14202e;font-size:18px;text-overflow:ellipsis;white-space:nowrap}.logout-button{min-width:54px;min-height:32px;border:1px solid #cfe0ea;border-radius:8px;background:#fff;color:#526879;font-size:13px;font-weight:800}.account-icon{position:absolute;top:16px;right:18px;width:72px;height:72px;object-fit:cover;border-radius:18px}.balance-row{padding:16px;border-radius:8px;background:#eef8ff}.balance-row strong{color:#0d89d0;font-size:30px;line-height:1}.panel{padding:18px}.section-title h2{margin:0;font-size:18px;line-height:1.25}.amount-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.amount{min-height:76px;display:grid;place-items:center;gap:4px;border:1px solid #d8e3ea;border-radius:8px;background:#fbfdff;color:#1b2c3a;transition:border-color .2s ease,background .2s ease,transform .2s ease}.amount strong{font-size:21px;line-height:1}.amount span{color:#6a7c8b;font-size:13px;font-weight:700}.amount.active{border-color:#189ce6;background:#ecf8ff;color:#087dc1}.amount.disabled{cursor:not-allowed;opacity:.45}.payment-panel{gap:14px}.payment-option{min-height:70px;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid #d8e3ea;border-radius:8px;background:#fbfdff}.payment-option input{width:18px;height:18px;accent-color:#1598e6}.alipay-mark{width:38px;height:38px;display:grid;place-items:center;flex:0 0 auto;border-radius:8px;background:#1677ff;color:#fff;font-size:20px;font-weight:900}.payment-copy{display:grid;gap:4px;min-width:0}.payment-copy strong{font-size:16px}.payment-copy small{color:#789;font-size:12px}.pay-button{margin-top:2px}.pay-message{min-height:38px;display:flex;align-items:center;padding:10px 12px;border-radius:8px;background:#eefaf4;color:#16804b;font-size:14px;font-weight:700}.records-panel{gap:12px}.record-list{display:grid;gap:8px}.record-row{min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid #d8e3ea;border-radius:8px;background:#fbfdff}.record-row>div{min-width:0;display:grid;gap:4px}.record-row>div:last-child{text-align:right}.record-row strong{overflow:hidden;color:#1b2c3a;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.record-row span,.empty-record{color:#718392;font-size:12px;font-weight:700}.record-paid{color:#16804b!important}.record-pending{color:#c77912!important}.empty-record{min-height:42px;display:grid;place-items:center;border:1px dashed #cfdce5;border-radius:8px;background:#f8fbfd}.recharge-page{gap:10px}.account-card{gap:12px;padding:16px 14px 14px}.account-topline,.account-copy,.balance-row,.section-title{gap:10px}.account-copy,.account-topline{padding-right:72px}.account-topline .account-copy{padding-right:0}.account-icon{top:14px;right:14px;width:58px;height:58px}.balance-row{padding:12px}.balance-row strong{font-size:26px}.panel{padding:14px}.section-title h2{font-size:16px}.amount-grid{gap:8px}.amount{min-height:58px}.amount strong{font-size:19px}.payment-panel{gap:10px}.payment-option{min-height:58px;gap:10px;padding:10px}.alipay-mark{width:34px;height:34px}.pay-message{min-height:34px;padding:8px 10px}.records-panel,.record-list{gap:8px}.record-row{min-height:50px;gap:10px;padding:8px 10px}.empty-record{min-height:36px}@media(min-width:390px){.amount-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
