@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/be-vietnam-pro-vietnamese-400-normal-CRcqvyg1.woff2)format("woff2"),url(/assets/be-vietnam-pro-vietnamese-400-normal-BuGn0gnm.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/be-vietnam-pro-latin-ext-400-normal-CiZNW1ec.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-ext-400-normal-DYBYyMQr.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/be-vietnam-pro-latin-400-normal-PpnXBOrz.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-400-normal-bXgqVju9.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/be-vietnam-pro-vietnamese-500-normal-DREgrEoJ.woff2)format("woff2"),url(/assets/be-vietnam-pro-vietnamese-500-normal-CfdwVo8-.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/be-vietnam-pro-latin-ext-500-normal-h0Fp6aX0.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-ext-500-normal-CK0UkkKf.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/be-vietnam-pro-latin-500-normal-B6LVzGNe.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-500-normal-BJkVuMHw.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/be-vietnam-pro-vietnamese-600-normal-nyU-ZL2p.woff2)format("woff2"),url(/assets/be-vietnam-pro-vietnamese-600-normal-DkpCIyan.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/be-vietnam-pro-latin-ext-600-normal-BNd8euf0.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-ext-600-normal-BeUwKxhG.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/be-vietnam-pro-latin-600-normal-BZDkUTrt.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-600-normal-5IO4e7bK.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/be-vietnam-pro-vietnamese-700-normal-Csr0PCuG.woff2)format("woff2"),url(/assets/be-vietnam-pro-vietnamese-700-normal-By_5yT39.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/be-vietnam-pro-latin-ext-700-normal-C8_gqRu2.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-ext-700-normal-4Hjo2OtD.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/be-vietnam-pro-latin-700-normal-DlW1Zbsh.woff2)format("woff2"),url(/assets/be-vietnam-pro-latin-700-normal-C2EtzaOi.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--brand-primary:#0b1e78;--brand-primary-dark:#08185a;--brand-primary-darker:#071555;--brand-primary-deep:#0a1a5c;--brand-primary-soft:#94a8e0;--brand-primary-bright:#3aa9ff;--brand-primary-lighter:#7aa1ff;--brand-primary-bg:#e7ecfb;--brand-primary-bg-soft:#eef2ff;--brand-accent:#f57c1f;--brand-accent-dark:#d96414;--brand-accent-deep:#c4651a;--brand-accent-soft:#fbc69a;--brand-accent-bright:#ffa247;--brand-accent-bg:#fff5eb;--brand-accent-bg-border:#ffd0a8}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:#f0f2f5;width:100%;height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Be Vietnam Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.booking-container{--grid-cell-width:54px;--court-label-width:96px;background:#fff;flex-direction:column;max-width:1024px;min-height:calc(100vh - 56px);margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}.booking-header{color:#fff;z-index:20;background:#0b1e78;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.booking-title{color:#fff;text-align:center;flex:1;margin:0;font-size:16px;font-weight:600}.booking-header .date-picker{background:#fff3;border:none;border-radius:6px}.booking-header .date-picker input{font-weight:500;color:#fff!important}.booking-header .date-picker .anticon{color:#fff}.booking-legend{border-bottom:1px solid #f0f0f0;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 16px;display:flex}.legend-item{align-items:center;gap:4px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:16px;height:16px;display:inline-block}.legend-label{color:#333;white-space:nowrap;font-size:12px}.view-price-link{color:#0b1e78;white-space:nowrap;margin-left:auto;font-size:12px;font-weight:600}.booking-notice{text-align:center;background:#fff5eb;border-bottom:none;padding:8px 16px}.booking-grid-wrapper{flex:1;display:flex;position:relative;overflow:hidden}.court-labels{width:var(--court-label-width);z-index:10;background:#fff;border-right:2px solid #c2c2c2;flex-shrink:0;box-shadow:2px 0 6px #0000000f}.court-label-header{background:#f5f5f5;border-bottom:1px solid #c8c8c8;width:100%;height:36px}.court-label{color:#333;white-space:nowrap;text-overflow:ellipsis;background:#fafafa;border-bottom:1px solid #cecece;align-items:center;width:100%;height:36px;padding:0 10px;font-size:12px;font-weight:600;display:flex;overflow:hidden}.grid-scroll{-webkit-overflow-scrolling:touch;flex:1;overflow:auto hidden}.grid-inner{flex-direction:column;display:flex}.time-header-row{z-index:5;background:#0b1e78;height:36px;display:flex;position:sticky;top:0;overflow:visible}.time-header-cell{min-width:var(--grid-cell-width);color:#fff;border-right:none;flex:1;font-size:12px;font-weight:600;position:relative}.time-header-cell.boundary-cell{border-right:none;flex:0 0 0;width:0;min-width:0;overflow:visible}.time-header-label{white-space:nowrap;pointer-events:none;position:absolute;top:50%;left:0;transform:translate(-50%,-50%)}.time-header-label.first{transform:translateY(-50%)}.time-header-label.end{left:auto;right:0;transform:translateY(-50%)}.court-row{border-bottom:none;display:flex}.grid-cell{min-width:var(--grid-cell-width);cursor:pointer;border-bottom:1px solid #cecece;border-right:1px solid #cecece;flex:1;height:36px;transition:all .15s;position:relative}.grid-cell.past-slot{cursor:not-allowed;pointer-events:none}.grid-cell.past-slot.past-empty{background:#d9d9d9}.grid-cell.past-slot.past-booked{background:#ca847d}.grid-cell.past-slot.past-locked{background:#ababab}.grid-cell.past-slot.past-selected{background:#94a8e0}.grid-cell.past-slot.past-empty:hover{background:#d9d9d9}.grid-cell.past-slot.past-booked:hover{background:#ca847d}.grid-cell.past-slot.past-locked:hover{background:#ababab}.grid-cell.past-slot.past-selected:hover{background:#94a8e0}.grid-cell.merge-right{border-right-color:#0000}.grid-cell.empty{background:#fff}.grid-cell.empty:not(.selected):not(.hovered-block):hover{background:#e7ecfb}.grid-cell.booked{cursor:not-allowed;background:#e74c3c}.grid-cell.booked-single{box-shadow:inset 1px 0 #c0392b,inset -1px 0 #c0392b,inset 0 1px #c0392b,inset 0 -1px #c0392b}.grid-cell.booked-start{border-right-color:#0000;box-shadow:inset 1px 0 #c0392b,inset 0 1px #c0392b,inset 0 -1px #c0392b}.grid-cell.booked-middle{border-right-color:#0000;box-shadow:inset 0 1px #c0392b,inset 0 -1px #c0392b}.grid-cell.booked-end{box-shadow:inset -1px 0 #c0392b,inset 0 1px #c0392b,inset 0 -1px #c0392b}.grid-cell.locked{cursor:not-allowed;background:#999}.grid-cell.selected{background:#3aa9ff;border-right-color:#0000}.grid-cell.hovered-block{background:#e7ecfb;border-right-color:#0000}.grid-cell.selected:hover,.grid-cell.hovered-block:hover{background:#e7ecfb}.grid-cell.hovered-single{box-shadow:inset 1px 0 #0b1e78,inset -1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.hovered-start{box-shadow:inset 1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.hovered-middle{box-shadow:inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.hovered-end{box-shadow:inset -1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.selected-single{box-shadow:inset 1px 0 #0b1e78,inset -1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.selected-start{box-shadow:inset 1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.selected-middle{box-shadow:inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.grid-cell.selected-end{box-shadow:inset -1px 0 #0b1e78,inset 0 1px #0b1e78,inset 0 -1px #0b1e78}.booking-slider{border-top:1px solid #f0f0f0;padding:16px 24px 8px}.booking-footer{padding:0 16px;padding-bottom:max(12px, env(safe-area-inset-bottom));z-index:20;background:#fff;border-top:1px solid #e0e0e0;position:sticky;bottom:56px}.booking-footer.has-selection{background:#0b1e78;border-top-color:#071555}.summary-toggle{cursor:pointer;color:#888;justify-content:center;padding:6px 0;font-size:12px;display:flex}.booking-footer.has-selection .summary-toggle{color:#e7ecfb}.summary-toggle:hover{color:#333}.booking-footer.has-selection .summary-toggle:hover{color:#fff}.summary-details{border-bottom:1px solid #f0f0f0;padding:8px 0}.booking-footer.has-selection .summary-details{border-bottom-color:#fff3}.summary-line{color:#333;padding:2px 0;font-size:13px;line-height:1.6}.booking-footer.has-selection .summary-line{color:#eef2ff}.summary-court{margin-right:4px;font-weight:600}.summary-range{color:#555}.booking-footer.has-selection .summary-range{color:#eef2ff}.summary-totals{color:#c0392b;justify-content:space-between;padding:10px 0;font-size:13px;font-weight:600;display:flex}.booking-footer.has-selection .summary-totals{color:#fff}.next-btn{border-radius:8px;height:48px;font-size:16px;font-weight:700;background:#f57c1f!important;border-color:#f57c1f!important}.next-btn:hover:not(:disabled){background:#d96414!important;border-color:#d96414!important}.next-btn:disabled{color:#fff!important;background:#fbc69a!important;border-color:#fbc69a!important}.booking-info-modal-overlay{z-index:1200;opacity:0;background:#00000073;justify-content:center;align-items:center;padding:16px;transition:opacity .22s;display:flex;position:fixed;inset:0}.booking-info-modal-dialog{opacity:0;background:#0a1a5c;border-radius:8px;width:min(760px,100%);transition:transform .22s cubic-bezier(.2,.8,.2,1),opacity .18s;position:relative;overflow:hidden;transform:translateY(16px)scale(.97);box-shadow:0 16px 48px #00000059}.booking-info-modal-overlay.is-open{opacity:1}.booking-info-modal-overlay.is-open .booking-info-modal-dialog{opacity:1;transform:translateY(0)scale(1)}.booking-info-modal-overlay.is-closing{opacity:0}.booking-info-modal-overlay.is-closing .booking-info-modal-dialog{opacity:0;transform:translateY(12px)scale(.98)}.booking-info-modal-close{color:#fff;cursor:pointer;z-index:1;background:#00000052;border:1px solid #ffffff47;border-radius:999px;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;transition:background .18s,border-color .18s,transform .18s;display:flex;position:absolute;top:10px;right:10px}.booking-info-modal-close:hover{background:#fff3;border-color:#fff9;transform:scale(1.05)}.booking-info-modal-close:active{transform:scale(.96)}@media (width<=768px){.booking-container{--grid-cell-width:40px;--court-label-width:72px}.booking-header{padding:10px 12px}.booking-title{font-size:14px}.court-label{padding:0 4px;font-size:11px}.time-header-cell{font-size:11px}.grid-cell{height:30px}.court-label-header,.time-header-row{height:32px}.court-label{height:30px}}.booking-info-page{color:#fff;background:#0a1a5c;min-height:100vh}.booking-info-page.in-modal{color:#fff;background:#0a1a5c;border-radius:8px;min-height:auto;padding:8px}.bi-header{border-bottom:1px solid #ffffff14;justify-content:center;align-items:center;padding:12px 10px;display:flex}.bi-header-title{font-size:15px;font-weight:700}.bi-section{background:#ffffff0f;border-radius:6px;margin:8px;padding:10px 12px}.bi-section:first-of-type{margin-top:4px}.bi-section-title{text-align:left;color:#ffa247;justify-content:flex-start;align-items:center;margin:0 0 8px;font-size:14px;font-weight:700;display:flex}.bi-section-title.booking-title{color:#ffa247}.bi-icon{margin-right:4px}.bi-text{color:#e0e0e0;margin:0 0 5px;font-size:13px;line-height:1.5}.bi-text b{color:#fff;font-weight:700}.bi-amount{color:#ffa247;font-weight:700}.bi-total{color:#ffa247;margin-top:4px;font-size:14px;font-weight:700}.bi-payment-section{padding:0;overflow:hidden}.bi-payment-row{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13px;display:flex}.bi-discount-row{border-bottom:1px solid #ffffff14}.bi-discount-link{color:#7aa1ff;font-size:13px;text-decoration:none}.bi-discount-link:hover{text-decoration:underline}.bi-plus{vertical-align:middle;border:1.5px solid #7aa1ff;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;margin-left:4px;font-size:13px;display:inline-flex}.bi-service-btn{text-align:center;cursor:pointer;border:1px dashed #ffffff40;border-radius:4px;margin:8px 12px 10px;padding:10px;font-size:13px}.bi-service-btn:hover{background:#ffffff0d}.bi-form{flex-direction:column;gap:4px;padding:4px 8px 16px;display:flex}.bi-label{color:#fff;text-transform:uppercase;margin-top:6px;font-size:12px;font-weight:700}.bi-input{border-radius:6px}.bi-phone-prefix{color:#fff;font-size:13px;font-weight:700}.bi-confirm-btn{color:#fff;background:#f57c1f;border-color:#f57c1f;border-radius:6px;height:44px;margin-top:12px;font-size:15px;font-weight:700}.bi-confirm-btn:hover,.bi-confirm-btn:focus{color:#fff!important;background:#d96414!important;border-color:#d96414!important}.bottom-nav{z-index:1000;height:56px;padding-bottom:env(safe-area-inset-bottom,0);background:#fff;border-top:1px solid #e0e0e0;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 8px #0000000f}.bottom-nav-item{cursor:pointer;color:#999;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:0;transition:color .2s;display:flex;position:relative}.bottom-nav-item:before{content:"";background:0 0;border-radius:0 0 3px 3px;height:3px;transition:background .2s;position:absolute;top:0;left:20%;right:20%}.bottom-nav-item.active,.bottom-nav-item.notify-enabled{color:#0b1e78}.bottom-nav-item.active:before{background:#0b1e78}.bottom-nav-item:active{opacity:.7}.bottom-nav-item:disabled{opacity:.55;cursor:not-allowed}.bottom-nav-icon{font-size:20px;line-height:1}.bottom-nav-label{font-size:11px;font-weight:600;line-height:1.2}.app-content-with-nav{padding-bottom:calc(56px + env(safe-area-inset-bottom,0))}.history-page{background:#fff;min-height:100vh}.history-topbar{border-bottom:1px solid #e9ecef;justify-content:flex-end;padding:8px;display:flex}.history-loading,.history-empty{justify-content:center;align-items:center;min-height:60vh;display:flex}.history-list{width:100%}.history-card{border-bottom:1px solid #e9ecef;padding:8px 10px}.history-card-head{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.history-badge{color:#fff;clip-path:polygon(0 0,100% 0,calc(100% - 10px) 50%,100% 100%,0 100%);background:#0b1e78;padding:3px 12px 3px 10px;font-size:12px;font-weight:600;display:inline-block}.history-cluster{color:#b46a2a;margin-bottom:4px;font-weight:700;display:block}.history-detail{margin-bottom:3px}.history-line{color:#2f3e46;font-size:14px}.history-time-range{font-weight:700}.history-amount{color:#0b1e78;margin-top:4px;font-weight:700;display:block}@media (width<=768px){.history-line{font-size:13px}}.auth-page{background:#f0f2f5;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{border-radius:12px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 10px 24px #0000001f}.auth-card .ant-card-head{color:#fff;background:#0b1e78}.auth-card .ant-card-head-title{color:#fff;font-weight:700}.auth-submit{border-radius:8px;height:44px;font-weight:700;background:#f57c1f!important;border-color:#f57c1f!important}.auth-submit:hover:not(:disabled){background:#d96414!important;border-color:#d96414!important}.auth-footer{text-align:center;margin-top:8px}.auth-link{color:#0b1e78;font-weight:600}.pay-page{background:#f5f5f5;min-height:100vh}.pay-header{color:#fff;background:#0b1e78;align-items:center;padding:12px 16px;display:flex}.pay-back{color:#fff;cursor:pointer;background:0 0;border:none;margin-right:12px;font-size:16px}.pay-header-title{font-size:16px;font-weight:700}.pay-body{gap:16px;max-width:1100px;margin:0 auto;padding:16px;display:flex}.pay-left{flex:1;min-width:0}.pay-bank-card{background:#fff;border-radius:8px;margin-bottom:12px;padding:16px}.pay-bank-content{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.pay-bank-info{flex:1;min-width:0}.pay-bank-heading{margin:0 0 10px;font-size:15px;font-weight:700}.pay-bank-line{color:#333;margin:0 0 6px;font-size:14px}.pay-copy-btn{cursor:pointer;color:#888;background:0 0;border:none;margin-left:6px;font-size:14px}.pay-copy-btn:hover{color:#0b1e78}.pay-bank-qr{object-fit:contain;border:1px solid #e0e0e0;border-radius:8px;flex-shrink:0;width:180px;height:auto}.pay-notice{color:#333;background:#e7ecfb;border-left:4px solid #0b1e78;border-radius:4px;margin-bottom:12px;padding:10px 14px;font-size:13px}.pay-notice-icon{margin-right:6px}.pay-notice-amount{color:#c62828}.pay-instruction{color:#666;text-align:center;margin-bottom:16px;font-size:13px}.pay-upload-section{gap:12px;margin-bottom:16px;display:flex}.pay-upload-box{cursor:pointer;text-align:center;background:#fff;border:2px dashed #ccc;border-radius:8px;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:160px;padding:16px;transition:border-color .2s;display:flex}.pay-upload-box:hover{border-color:#0b1e78}.pay-upload-box.has-image{border-style:solid;border-color:#0b1e78;padding:4px}.pay-upload-preview{object-fit:contain;border-radius:4px;max-width:100%;max-height:180px}.pay-upload-icon{color:#aaa;margin-bottom:8px;font-size:32px}.pay-upload-text{color:#999;font-size:12px}.pay-confirm-btn{background:#0b1e78;border-color:#0b1e78;border-radius:8px;height:48px;font-size:15px;font-weight:700}.pay-confirm-btn:hover,.pay-confirm-btn:focus{background:#08185a!important;border-color:#08185a!important}.pay-right{flex-shrink:0;width:340px}.pay-summary-card{background:#fff;border-radius:8px;margin-bottom:12px;padding:16px}.pay-summary-heading{color:#333;margin:0 0 12px;font-size:15px;font-weight:700}.pay-summary-row{color:#333;border-bottom:1px solid #f0f0f0;align-items:flex-start;gap:8px;padding:8px 0;font-size:13px;display:flex}.pay-summary-row:last-child{border-bottom:none}.pay-summary-label{color:#888;flex-shrink:0;min-width:100px}.pay-summary-detail{margin:2px 0 0;font-size:13px}.pay-summary-amount{color:#c62828}.pay-note-card{background:#fff5eb;border:1px solid #ffd0a8;border-radius:8px;padding:12px 16px}.pay-note-heading{color:#c4651a;margin:0 0 6px;font-size:20px;font-weight:700}.pay-note-text{color:#c4651a;margin:0;font-size:15px}.pay-countdown{text-align:center;background:#e7ecfb;border:1px solid #0b1e78;border-radius:8px;margin-bottom:12px;padding:12px 16px}.pay-countdown.expired{background:#fbe9e7;border-color:#c62828}.pay-countdown-text{color:#0b1e78;font-size:14px;font-weight:500}.pay-countdown-text b{color:#c62828;font-size:18px;font-weight:700}.pay-countdown-text.expired{color:#c62828;font-size:15px;font-weight:700}@media (width<=768px){.pay-body,.pay-bank-content{flex-direction:column}.pay-bank-qr{align-self:center;width:220px}.pay-right{width:100%}.pay-upload-section{flex-direction:column}}.user-page{background:#f5f5f5;max-width:1024px;min-height:100vh;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.user-profile-card{color:#fff;background:#0b1e78;flex-wrap:wrap;align-items:center;gap:16px;padding:24px 20px;display:flex}.user-avatar{background:#fff3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:26px;display:flex}.user-info{flex:1;min-width:0}.user-info-row{align-items:center;gap:8px;margin-bottom:4px;font-size:14px;display:flex}.user-info-row:last-child{margin-bottom:0}.user-info-icon{opacity:.8;font-size:14px}.user-info-value{text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.user-logout-btn{border-radius:8px;flex-shrink:0;font-weight:600}.user-history-section{background:#fff;margin-top:8px}.user-history-heading{color:#0b1e78;border-bottom:1px solid #e9ecef;margin:0;padding:14px 16px 10px;font-size:16px;font-weight:700}.user-history-loading,.user-history-empty{justify-content:center;align-items:center;min-height:40vh;display:flex}.user-history-list{width:100%}.user-history-card{border-bottom:1px solid #e9ecef;padding:10px 16px}.user-history-card-head{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.user-history-badge{color:#fff;clip-path:polygon(0 0,100% 0,calc(100% - 10px) 50%,100% 100%,0 100%);background:#0b1e78;padding:3px 12px 3px 10px;font-size:12px;font-weight:600;display:inline-block}.user-history-cluster{color:#b46a2a;margin-bottom:4px;font-weight:700;display:block}.user-history-detail{margin-bottom:3px}.user-history-line{color:#2f3e46;font-size:14px}.user-history-time-range{font-weight:700}.user-history-amount{color:#0b1e78;margin-top:4px;font-weight:700;display:block}@media (width<=768px){.user-profile-card{padding:16px 14px}.user-avatar{width:44px;height:44px;font-size:20px}.user-info-row,.user-history-line{font-size:13px}}
