@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-container.is-choosing-customer-type{position:relative}.customer-type-overlay{z-index:1300;background:#0b1e78;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.customer-type-dialog{background:#fff;border-radius:8px;width:min(420px,100%);padding:18px 16px 14px;box-shadow:0 18px 40px #050e3c59}.customer-type-title{color:#0b1e78;text-align:center;margin:0 0 14px;font-size:18px;font-weight:700}.customer-type-options{flex-direction:column;gap:12px;margin-bottom:16px;display:flex}.customer-type-option{color:#1f2f6d;cursor:pointer;align-items:center;gap:10px;font-size:14px;font-weight:500;display:flex}.customer-type-option input[type=radio]{accent-color:#0b1e78;width:16px;height:16px}.customer-type-continue-btn{border-radius:8px;height:40px;font-weight:700}.booking-loading-screen{background:#f7f9ff;flex-direction:column;justify-content:center;align-items:center;gap:14px;min-height:calc(100vh - 56px);display:flex}.booking-loading-spinner{border:3px solid #d6defb;border-top-color:#0b1e78;border-radius:50%;width:42px;height:42px;animation:.85s linear infinite booking-loading-rotate}.booking-loading-text{color:#0b1e78;margin:0;font-size:14px;font-weight:600}@keyframes booking-loading-rotate{to{transform:rotate(360deg)}}.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-back-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;margin-right:8px;display:inline-flex}.booking-back-btn:hover{background:#ffffff4d}.booking-header .date-picker{background:#fff3;border:none;border-radius:6px}.booking-header-actions{align-items:center;gap:8px;display:flex}.booking-header .date-picker input{font-weight:500;color:#fff!important}.booking-header .date-picker .anticon{color:#fff}.booking-search-input{width:180px}.booking-search-input .ant-input{color:#fff;background:#fff3;border:none;font-weight:500}.booking-search-input .ant-input::placeholder{color:#ffffffbf}.booking-search-input .ant-input-affix-wrapper{background:#fff3;border:none;border-radius:6px}.booking-search-input .anticon{color:#0b1e78;cursor:pointer;font-size:15px;font-weight:700}.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-admin-tip{color:#0b1e78;background:#e8f0ff;border-bottom:1px solid #d7e2ff;padding:8px 16px;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}.court-label.focus-row-label{color:#0b1e78;background:#dce8ff}.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.focus-column-header{background:#2b3d8b}.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;overflow:visible}.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:#8eb99e}.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:#8eb99e}.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{cursor:default;background:#fff}.grid-cell.empty:not(.selected):not(.hovered-block):hover{background:#e7ecfb}.grid-cell.booked{cursor:pointer;z-index:1;background:#2eab57}.grid-cell.paid{cursor:pointer;z-index:1;background:#3a8fd9}.booking-cell-details{width:calc(var(--booking-span,1) * 100%);pointer-events:none;color:#fff;text-align:center;text-shadow:0 1px 1px #0000004d;z-index:4;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:0 6px;font-size:11px;line-height:1.2;display:flex;position:absolute;top:0;bottom:0;left:0}.booking-cell-name,.booking-cell-phone{white-space:nowrap;text-overflow:ellipsis;width:100%;display:block;overflow:hidden}.booking-cell-name{font-weight:600}.booking-cell-details.is-compact{gap:0}.booking-cell-details.is-compact .booking-cell-name{font-size:12px}.booking-cell-details.is-compact .booking-cell-phone{display:none}.booking-hover-card{color:#fff;white-space:normal;opacity:0;pointer-events:none;background:#08113cf2;border-radius:8px;min-width:140px;max-width:220px;padding:6px 8px;font-size:12px;line-height:1.35;transition:opacity .15s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 8px 20px #0000004d}.booking-hover-name{font-weight:600}.booking-hover-phone{opacity:.95}.grid-cell.booked:hover .booking-hover-card,.grid-cell.is-booking-hovered .booking-hover-card{opacity:1}.grid-cell.booked-single{z-index:3;box-shadow:inset 1px 0 #248844,inset -1px 0 #248844,inset 0 1px #248844,inset 0 -1px #248844}.grid-cell.booked-start{z-index:3;border-right-color:#0000;box-shadow:inset 1px 0 #248844,inset 0 1px #248844,inset 0 -1px #248844}.grid-cell.booked-middle{z-index:2;border-right-color:#0000;box-shadow:inset 0 1px #248844,inset 0 -1px #248844}.grid-cell.booked-end{z-index:2;box-shadow:inset -1px 0 #248844,inset 0 1px #248844,inset 0 -1px #248844}.grid-cell.paid-single{z-index:3;box-shadow:inset 1px 0 #2a7ab8,inset -1px 0 #2a7ab8,inset 0 1px #2a7ab8,inset 0 -1px #2a7ab8}.grid-cell.paid-start{z-index:3;border-right-color:#0000;box-shadow:inset 1px 0 #2a7ab8,inset 0 1px #2a7ab8,inset 0 -1px #2a7ab8}.grid-cell.paid-middle{z-index:2;border-right-color:#0000;box-shadow:inset 0 1px #2a7ab8,inset 0 -1px #2a7ab8}.grid-cell.paid-end{z-index:2;box-shadow:inset -1px 0 #2a7ab8,inset 0 1px #2a7ab8,inset 0 -1px #2a7ab8}.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.focus-row,.grid-cell.focus-column{box-shadow:inset 0 0 0 9999px #0b1e781f}.grid-cell.focus-cell{box-shadow:inset 0 0 0 9999px #3aa9ff1f}.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}.booking-header-actions{gap:6px}.booking-search-input{width:132px}.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}}.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}.notification-tab-icon-wrap{position:relative}.bottom-nav-unread-badge{color:#fff;text-align:center;background:#e74c3c;border-radius:999px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;position:absolute;top:-6px;right:-12px}.bottom-nav-notification-overlay{z-index:1098;background:#00000047;border:none;position:fixed;inset:0}.bottom-nav-notification-sheet{width:100%;max-width:1024px;left:50%;bottom:calc(56px + env(safe-area-inset-bottom,0));z-index:1099;background:#fff;border-top-left-radius:12px;border-top-right-radius:12px;flex-direction:column;max-height:50vh;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 -10px 24px #0003}.bottom-nav-notification-header{color:#0b1e78;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:12px 14px;font-size:13px;font-weight:700;display:flex}.bottom-nav-mark-all-btn{color:#0b1e78;cursor:pointer;background:0 0;border:none;font-size:12px;font-weight:600}.bottom-nav-mark-all-btn:disabled{color:#9ca6cc;cursor:not-allowed}.bottom-nav-notification-list{overflow-y:auto}.bottom-nav-notification-item{text-align:left;cursor:pointer;background:#fff;border:none;border-bottom:1px solid #f2f2f2;width:100%;padding:10px 14px}.bottom-nav-notification-item.unread{background:#f2f7ff}.bottom-nav-notification-title{color:#1f2f6d;font-size:13px;font-weight:700}.bottom-nav-notification-body{color:#444;margin-top:3px;font-size:12px}.bottom-nav-notification-time{color:#7f8db6;margin-top:5px;font-size:11px}.bottom-nav-notification-empty{text-align:center;color:#8b94b4;padding:20px 14px;font-size:12px}.app-content-with-nav{padding-bottom:calc(56px + env(safe-area-inset-bottom,0))}.cluster-detail-page{background:#f5f6fa;max-width:1280px;min-height:100vh;margin:0 auto;padding:0 0 80px}.cluster-detail-loading,.cluster-detail-empty{color:#5a6478;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;display:flex}.cluster-detail-banner{aspect-ratio:1024/200;background:linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-bright) 100%);width:100%;max-height:240px;position:relative;overflow:hidden}.cluster-detail-banner-image{object-fit:cover;width:100%;height:100%;display:block}.cluster-detail-banner-placeholder{color:#fff;letter-spacing:1px;text-shadow:0 2px 8px #00000040;justify-content:center;align-items:center;width:100%;height:100%;font-size:28px;font-weight:800;display:flex}.cluster-detail-back{z-index:2;width:34px;height:34px;color:var(--brand-primary);cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;transition:background .15s,color .15s;display:inline-flex;position:absolute;top:14px;left:14px;box-shadow:0 2px 8px #0003}.cluster-detail-back:hover{color:var(--brand-accent);background:#fff}.cluster-detail-header{background:#fff;border-bottom:1px solid #e4e8f3;grid-template-columns:1fr auto;align-items:end;gap:16px;min-height:68px;padding:10px 20px 0 120px;display:grid;position:relative}.cluster-detail-avatar{width:88px;height:88px;color:var(--brand-accent);background:#fff5eb;border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:26px;font-weight:800;display:flex;position:absolute;top:-30px;left:20px;overflow:hidden;box-shadow:0 4px 12px #0b1e782e}.cluster-detail-avatar img{object-fit:cover;width:100%;height:100%;display:block}.cluster-detail-head-info{grid-column:1/-1;padding:8px 0}.cluster-detail-name{color:var(--brand-primary);letter-spacing:.2px;margin:0;font-size:18px;font-weight:800}.cluster-detail-stars{color:#f5b301;gap:2px;margin-top:2px;font-size:12px;display:inline-flex}.cluster-detail-tabs{scrollbar-width:none;grid-area:2/1/3/2;align-items:center;gap:28px;display:flex;overflow-x:auto}.cluster-detail-tabs::-webkit-scrollbar{display:none}.cluster-detail-tab{color:#5a6478;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 2px 12px;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.cluster-detail-tab:hover{color:var(--brand-primary)}.cluster-detail-tab.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}.cluster-detail-book-btn{background:linear-gradient(180deg, #ffb24a 0%, var(--brand-accent) 100%);color:#fff;letter-spacing:.4px;border:none;border-radius:6px;grid-area:2/2/3/3;place-self:center end;height:34px;margin-bottom:8px;padding:0 18px;font-size:13px;font-weight:800;transition:transform .16s,box-shadow .16s,filter .16s;box-shadow:0 3px 8px #f57c1f59}.cluster-detail-book-btn:hover,.cluster-detail-book-btn:focus{background:linear-gradient(180deg, var(--brand-accent-bright) 0%, var(--brand-accent-dark) 100%);color:#fff;filter:saturate(1.06);transform:translateY(-1px);box-shadow:0 4px 10px #f57c1f73}.cluster-detail-book-btn:active{transform:translateY(0);box-shadow:0 2px 6px #f57c1f5c}.cluster-detail-body{grid-template-columns:minmax(260px,360px) 1fr;align-items:start;gap:16px;padding:16px 20px 24px;display:grid}.cluster-detail-info-panel{background:linear-gradient(180deg, var(--brand-primary) 0%, var(--brand-primary-dark) 100%);color:#fff;border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;display:flex;box-shadow:0 4px 14px #0b1e7847}.cluster-detail-info-row{border-bottom:1px solid #ffffff1f;align-items:flex-start;gap:10px;padding:6px 0;font-size:13.5px;line-height:1.45;display:flex}.cluster-detail-info-row:last-child{border-bottom:none}.cluster-detail-info-icon{color:var(--brand-accent-soft);flex-shrink:0;margin-top:3px;font-size:14px}.cluster-detail-info-link{color:#fff;border-bottom:1px dashed #fff6;font-weight:600;text-decoration:none}.cluster-detail-info-link:hover{color:var(--brand-accent-soft)}.cluster-detail-layout-panel{background:#fff;border:1px solid #e4e8f3;border-radius:10px;justify-content:center;align-items:center;min-height:240px;padding:14px;display:flex;box-shadow:0 2px 8px #0b1e780f}.cluster-detail-layout-image{border-radius:6px;width:100%;max-width:100%;height:auto;display:block}.cluster-detail-layout-placeholder{color:#8b94a7;font-size:14px}@media (width<=900px){.cluster-detail-body{grid-template-columns:1fr}.cluster-detail-header{padding:10px 16px 0 110px}}@media (width<=600px){.cluster-detail-banner{aspect-ratio:16/7}.cluster-detail-header{grid-template-columns:1fr;min-height:auto;padding:8px 14px 0}.cluster-detail-avatar{width:72px;height:72px;margin:-44px 0 6px;font-size:22px;position:static}.cluster-detail-head-info{padding:0 0 4px}.cluster-detail-tabs{grid-area:auto;gap:18px;padding-bottom:4px}.cluster-detail-book-btn{grid-area:auto;justify-self:stretch;width:100%;margin-bottom:10px}.cluster-detail-body{padding:12px 14px 24px}.cluster-detail-info-row{font-size:13px}}.clusters-page{background:#f5f6fa;max-width:1024px;min-height:100vh;margin:0 auto;padding:16px 14px 80px}.clusters-header{margin-bottom:14px;padding:2px 2px 0}.clusters-title{color:var(--brand-primary);letter-spacing:.2px;margin:0;font-size:20px;font-weight:800}.clusters-subtitle{color:#5a6478;margin:4px 0 0;font-size:13px}.clusters-loading,.clusters-empty{justify-content:center;align-items:center;min-height:50vh;display:flex}.clusters-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.cluster-card{cursor:pointer;background:#fff;border:1px solid #e4e8f3;border-radius:12px;flex-direction:column;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0b1e780f}.cluster-card:focus-visible{outline:2px solid var(--brand-primary);outline-offset:2px}.cluster-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0b1e781f}.cluster-card-banner{aspect-ratio:16/9;background:linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-bright) 100%);width:100%;position:relative;overflow:hidden}.cluster-banner-image{object-fit:cover;width:100%;height:100%;display:block}.cluster-banner-placeholder{color:#fff;text-shadow:0 2px 6px #0003;text-align:center;justify-content:center;align-items:center;width:100%;height:100%;padding:14px;font-size:22px;font-weight:800;display:flex}.cluster-banner-badges{z-index:2;gap:6px;display:flex;position:absolute;top:10px;left:10px}.cluster-badge{color:#fff;letter-spacing:.2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:999px;align-items:center;padding:3px 10px 3px 8px;font-size:11px;font-weight:700;display:inline-flex;box-shadow:0 2px 6px #0000002e}.cluster-badge-primary{background:linear-gradient(90deg, var(--brand-primary) 0%, var(--brand-primary-lighter) 100%)}.cluster-badge-accent{background:linear-gradient(90deg, #ffb24a 0%, var(--brand-accent) 100%)}.cluster-banner-actions{z-index:2;gap:6px;display:flex;position:absolute;top:8px;right:8px}.cluster-banner-icon-btn{width:28px;height:28px;color:var(--brand-primary);cursor:pointer;background:#ffffffd9;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex;box-shadow:0 2px 6px #00000026}.cluster-banner-icon-btn:hover{color:var(--brand-accent);background:#fff}.cluster-card-body{grid-template-columns:44px 1fr auto;align-items:center;gap:10px;padding:10px 12px 12px;display:grid}.cluster-logo-sm{background:var(--brand-primary-bg);width:44px;height:44px;color:var(--brand-primary);border:1px solid #e4e8f3;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:800;display:flex;overflow:hidden}.cluster-logo-sm img{object-fit:cover;width:100%;height:100%;display:block}.cluster-info{min-width:0}.cluster-name{color:var(--brand-primary);text-overflow:ellipsis;white-space:nowrap;margin:0 0 2px;font-size:14px;font-weight:800;line-height:1.2;overflow:hidden}.cluster-line{color:#4b5566;align-items:flex-start;gap:6px;margin:2px 0 0;font-size:12px;line-height:1.35;display:flex;overflow:hidden}.cluster-line span{text-overflow:ellipsis;-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.cluster-line-icon{color:var(--brand-accent);flex-shrink:0;margin-top:2px;font-size:12px}.cluster-note{color:#7a6135}.cluster-note .cluster-line-icon{color:var(--brand-accent-dark)}.cluster-book-btn{background:linear-gradient(180deg, #ffb24a 0%, var(--brand-accent) 100%);color:#fff;letter-spacing:.4px;border:none;border-radius:6px;align-self:center;height:30px;padding:0 12px;font-size:12px;font-weight:800;transition:transform .16s,box-shadow .16s,filter .16s;box-shadow:0 3px 8px #f57c1f59}.cluster-book-btn:hover,.cluster-book-btn:focus{background:linear-gradient(180deg, var(--brand-accent-bright) 0%, var(--brand-accent-dark) 100%);color:#fff;filter:saturate(1.06);transform:translateY(-1px);box-shadow:0 4px 10px #f57c1f73}.cluster-book-btn:active{transform:translateY(0);box-shadow:0 2px 6px #f57c1f5c}@media (width<=520px){.clusters-page{padding:12px 10px 80px}.clusters-grid{grid-template-columns:1fr;gap:12px}.cluster-card-body{grid-template-columns:40px 1fr auto;padding:8px 10px 10px}.cluster-logo-sm{width:40px;height:40px;font-size:16px}.cluster-name{font-size:13px}.cluster-line{font-size:11.5px}.cluster-book-btn{height:28px;padding:0 10px;font-size:11.5px}}.booking-info-page{color:#fff;background:#0a1a5c;width:100%;max-width:1024px;min-height:100vh;margin:0 auto}.bi-page-actions{justify-content:flex-start;padding:12px 16px 0;display:flex;position:relative}.bi-back-btn{z-index:1;color:#fff;cursor:pointer;background:0 0;border:none;padding:0;font-size:24px;font-weight:700;line-height:1;position:relative}.bi-page-title{color:#fff;margin:0;font-size:20px;font-weight:700;line-height:1.2;position:absolute;left:50%;transform:translate(-50%)}.bi-loading-wrap,.bi-error-wrap{justify-content:center;align-items:center;min-height:180px;padding:12px 16px;display:flex}.bi-not-found-card{text-align:center;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;width:min(460px,100%);padding:20px 18px}.bi-not-found-icon{font-size:30px;line-height:1}.bi-not-found-title{color:#fff;margin-top:8px;font-size:18px;font-weight:700}.bi-not-found-message{color:#d6dcf2;margin-top:8px;display:block}.bi-not-found-actions{margin-top:14px}.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-link{color:#9cc2ff}.bi-link:hover{color:#c4dbff}.bi-phone-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.bi-contact-actions{align-items:center;gap:6px;display:inline-flex}.bi-contact-btn{color:#fff;background:0 0;border:none;justify-content:center;align-items:center;font-size:20px;line-height:1;display:inline-flex}.bi-contact-btn:hover{opacity:.85}.bi-contact-zalo{width:42px;height:42px}.bi-zalo-icon{object-fit:contain;width:100%;height:100%;display:block}.bi-amount{color:#ffa247;font-weight:700}.bi-total{color:#ffa247;margin-top:4px;font-size:14px;font-weight:700}.bi-admin-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:10px;display:grid}.bi-admin-btn{width:100%;height:40px;font-weight:600}.bi-media-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.bi-media-card{aspect-ratio:9/16;background:#ffffff14;border:1px solid #ffffff1f;border-radius:8px;overflow:hidden}.bi-media-image{object-fit:cover;width:100%;height:100%;display:block}.bi-media-empty{color:#c3cbe6;justify-content:center;align-items:center;width:100%;height:100%;font-size:12px;font-weight:600;display:flex}.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}.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}}.home-page{background:#f0f2f5;min-height:100vh;padding:16px}.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}.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.is-waiting{cursor:pointer;transition:background-color .2s}.user-history-card.is-waiting:hover{background:#f8fbff}.user-history-card.is-waiting:focus-visible{outline-offset:-2px;outline:2px solid #0b1e78}.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}.user-history-pay-link{margin-top:2px;padding-left:0;font-weight:600}.user-push-toggle-row{border-top:1px solid #ffffff26;margin-top:8px;padding-top:8px}.user-push-hint{opacity:.7;flex-basis:100%;margin-top:2px;padding-left:2px;font-size:11px}@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}.user-push-label{font-size:12px}}.notif-gate-overlay{z-index:9999;background:#0b1e78;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.notif-gate-card{text-align:center;background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px 32px 32px;box-shadow:0 24px 60px #0006}.notif-gate-icon{color:#0b1e78;background:#e8f0ff;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;font-size:36px;display:flex}.notif-gate-title{color:#0b1e78;margin:0 0 12px;font-size:22px;font-weight:700}.notif-gate-desc{color:#555;margin:0 0 28px;font-size:14px;line-height:1.6}.notif-gate-card .ant-btn-primary{background:#0b1e78;border-color:#0b1e78;border-radius:8px;min-width:180px;height:44px;font-size:15px;font-weight:700}.notif-gate-card .ant-btn-primary:hover:not(:disabled){background:#1a2f8a;border-color:#1a2f8a}
