:root{--PhoneInput-color--focus: #03b2cb;--PhoneInputInternationalIconPhone-opacity: .8;--PhoneInputInternationalIconGlobe-opacity: .65;--PhoneInputCountrySelect-marginRight: .35em;--PhoneInputCountrySelectArrow-width: .3em;--PhoneInputCountrySelectArrow-marginLeft: var(--PhoneInputCountrySelect-marginRight);--PhoneInputCountrySelectArrow-borderWidth: 1px;--PhoneInputCountrySelectArrow-opacity: .45;--PhoneInputCountrySelectArrow-color: currentColor;--PhoneInputCountrySelectArrow-color--focus: var(--PhoneInput-color--focus);--PhoneInputCountrySelectArrow-transform: rotate(45deg);--PhoneInputCountryFlag-aspectRatio: 1.5;--PhoneInputCountryFlag-height: 1em;--PhoneInputCountryFlag-borderWidth: 1px;--PhoneInputCountryFlag-borderColor: rgba(0,0,0,.5);--PhoneInputCountryFlag-borderColor--focus: var(--PhoneInput-color--focus);--PhoneInputCountryFlag-backgroundColor--loading: rgba(0,0,0,.1)}.PhoneInput{display:flex;align-items:center}.PhoneInputInput{flex:1;min-width:0}.PhoneInputCountryIcon{width:calc(var(--PhoneInputCountryFlag-height) * var(--PhoneInputCountryFlag-aspectRatio));height:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--square{width:var(--PhoneInputCountryFlag-height)}.PhoneInputCountryIcon--border{background-color:var(--PhoneInputCountryFlag-backgroundColor--loading);box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor)}.PhoneInputCountryIconImg{display:block;width:100%;height:100%}.PhoneInputInternationalIconPhone{opacity:var(--PhoneInputInternationalIconPhone-opacity)}.PhoneInputInternationalIconGlobe{opacity:var(--PhoneInputInternationalIconGlobe-opacity)}.PhoneInputCountry{position:relative;align-self:stretch;display:flex;align-items:center;margin-right:var(--PhoneInputCountrySelect-marginRight)}.PhoneInputCountrySelect{position:absolute;top:0;left:0;height:100%;width:100%;z-index:1;border:0;opacity:0;cursor:pointer}.PhoneInputCountrySelect[disabled],.PhoneInputCountrySelect[readonly]{cursor:default}.PhoneInputCountrySelectArrow{display:block;content:"";width:var(--PhoneInputCountrySelectArrow-width);height:var(--PhoneInputCountrySelectArrow-width);margin-left:var(--PhoneInputCountrySelectArrow-marginLeft);border-style:solid;border-color:var(--PhoneInputCountrySelectArrow-color);border-top-width:0;border-bottom-width:var(--PhoneInputCountrySelectArrow-borderWidth);border-left-width:0;border-right-width:var(--PhoneInputCountrySelectArrow-borderWidth);transform:var(--PhoneInputCountrySelectArrow-transform);opacity:var(--PhoneInputCountrySelectArrow-opacity)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon+.PhoneInputCountrySelectArrow{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon--border{box-shadow:0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus),inset 0 0 0 var(--PhoneInputCountryFlag-borderWidth) var(--PhoneInputCountryFlag-borderColor--focus)}.PhoneInputCountrySelect:focus+.PhoneInputCountryIcon .PhoneInputInternationalIconGlobe{opacity:1;color:var(--PhoneInputCountrySelectArrow-color--focus)}@font-face{font-family:Inter;font-style:normal;font-weight:300 900;font-display:swap;src:url(/fonts/Inter-vietnamese.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:300 900;font-display:swap;src:url(/fonts/Inter-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Inter;font-style:normal;font-weight:300 900;font-display:swap;src:url(/fonts/Inter-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Racing Sans One;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/RacingSansOne-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Racing Sans One;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/RacingSansOne-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #06090f;--bg2: #0b1120;--bg3: #0f1829;--bg4: #131f33;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.13);--ink-1: #f0f4ff;--ink-2: #8fa3c8;--ink-3: #3f5278;--ink-4: #243352;--blue: #4f8fff;--blue2: #1a56db;--blue-bg: rgba(37,99,235,.12);--blue-fg: #4f8fff;--blue-glow: rgba(37,99,235,.28);--gold: #f5a623;--gold2: #e8820c;--gold-bg: rgba(245,166,35,.1);--gold-fg: #f5a623;--gold-glow: rgba(245,166,35,.35);--gold-soft: rgba(245,166,35,.55);--green: #10b981;--green-bg: rgba(16,185,129,.12);--green-fg: #34d399;--red: #ef4444;--red-bg: rgba(239,68,68,.12);--cell-open: rgba(79,143,255,.07);--cell-open-h: rgba(79,143,255,.14);--cell-taken: rgba(239,68,68,.08);--cell-selected: rgba(245,166,35,.15);--sh-sm: 0 1px 4px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.2);--sh-md: 0 2px 8px rgba(0,0,0,.5), 0 8px 32px rgba(0,0,0,.3);--sh-lg: 0 4px 16px rgba(0,0,0,.6), 0 20px 56px rgba(0,0,0,.4);--r1: 8px;--r2: 12px;--r3: 18px;--r4: 24px;--ease: cubic-bezier(.16,1,.3,1);--primary: var(--gold);--surface: var(--bg2);font-family:Inter,DM Sans,system-ui,sans-serif;font-size:14px;color:var(--ink-1);-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:0;height:0}html{overflow-x:clip}body{overflow-x:clip;min-height:100vh;background:var(--bg);background-image:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(37,99,235,.1) 0%,transparent 65%),radial-gradient(ellipse 40% 30% at 85% 85%,rgba(245,166,35,.06) 0%,transparent 55%);background-attachment:fixed}button{font:inherit;border:none;cursor:pointer;background:none;color:inherit}#root{min-height:100vh;display:flex;flex-direction:column}.shell{display:flex;flex-direction:column;min-height:100vh;width:100%;max-width:100vw}.topbar-brand{display:flex;align-items:center;justify-content:space-between;height:54px;padding:0 20px 0 12px;background:#06090fe6;-webkit-backdrop-filter:blur(24px) saturate(1.8);backdrop-filter:blur(24px) saturate(1.8);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;flex-shrink:0;gap:12px}.topbar-brand .brand{flex:1;min-width:0}.topbar-nav{display:flex;align-items:stretch;height:40px;padding:0 12px;background:#06090fd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:54px;z-index:199;flex-shrink:0;gap:0;overflow-x:auto}.topbar-nav .tab{font-family:Racing Sans One,sans-serif;height:100%;display:flex;align-items:center;padding:0 14px;font-size:13px;font-weight:600;color:#92aad0;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .12s,border-color .12s;white-space:nowrap}.topbar-nav .tab:hover{color:#b8cceb}.topbar-nav .tab.active{color:var(--gold);border-bottom-color:var(--gold)}.topbar{display:flex;align-items:stretch;height:54px;padding:0 20px;background:#06090fe6;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;flex-shrink:0}.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;letter-spacing:-.01em;flex:0 0 auto;padding-right:12px}.brand-logo{height:32px;width:auto;max-width:120px;object-fit:contain;object-position:left center;border-radius:4px;flex-shrink:0;display:block}.brand-name{color:var(--gold);white-space:nowrap}.tabs{display:flex;align-items:center;gap:2px;flex:1 1 0%;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;padding:0 8px}.tab{padding:0 16px;height:100%;display:flex;align-items:center;font-size:13px;font-weight:600;color:#92aad0;white-space:nowrap;flex-shrink:0;border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.tab:hover{color:#b8cceb}.tab.active{color:var(--gold);border-bottom-color:var(--gold);font-weight:700}.topbar-right{display:flex;align-items:center;gap:8px;flex:0 0 auto;padding-left:12px}.auth-badge{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2);font-weight:500}.auth-name{max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot.green{background:var(--green);box-shadow:0 0 6px var(--green)}.link-btn{color:#92aad0;font-size:12px;padding:0 4px;transition:color .12s;white-space:nowrap}.link-btn:hover{color:#b8cceb}.link-btn.danger:hover{color:var(--red)}.lang-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--ink-2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.lang-btn:hover{border-color:#f5a6234d;color:var(--gold);background:#f5a6230f}.lang-btn svg{flex-shrink:0}.lang-dropdown{position:absolute;top:calc(100% + 6px);right:0;z-index:400;background:#0b1120f7;-webkit-backdrop-filter:blur(24px) saturate(1.8);backdrop-filter:blur(24px) saturate(1.8);border:1px solid rgba(245,166,35,.18);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0009;min-width:130px}.lang-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 14px;background:none;border:none;border-bottom:1px solid rgba(255,255,255,.05);color:var(--ink-2);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s,color .12s;text-align:left}.lang-option:last-child{border-bottom:none}.lang-option:hover{background:#f5a6230f;color:var(--ink-1)}.lang-option.active{color:var(--gold);font-weight:700}.lang-select{padding:5px 6px;border-radius:var(--r1);background:var(--bg3);border:1px solid var(--border);color:var(--ink-2);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .12s;flex-shrink:0}.lang-select:hover{border-color:var(--border2)}.lang-select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}@media (max-width: 640px){.topbar{display:grid;grid-template-areas:"brand right" "tabs tabs";grid-template-columns:1fr auto;grid-template-rows:48px 44px;height:auto;padding:0;align-items:center}.brand{grid-area:brand;padding:0 0 0 14px;min-width:0}.brand-name{overflow:hidden;text-overflow:ellipsis;max-width:140px}.tabs{grid-area:tabs;border-top:1px solid var(--border);padding:6px 10px;gap:4px;overflow-x:auto;align-items:center}.tab{padding:6px 16px;font-size:13px}.topbar-right{grid-area:right;padding:0 12px 0 8px;gap:6px}.auth-name{max-width:52px}.lang-btn-text{display:none}.lang-btn{padding:5px 7px;gap:0}}.flash-bar{padding:9px 20px;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:space-between}.success-flash{background:var(--green-bg);color:var(--green-fg);border-bottom:1px solid rgba(16,185,129,.2)}.error-flash{background:var(--red-bg);color:var(--red);border-bottom:1px solid rgba(239,68,68,.2)}.book-view{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:0;width:100%}.controls-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;width:100%;min-width:0;overflow:hidden}.date-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.date-strip::-webkit-scrollbar{height:0}.date-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 11px;border-radius:var(--r2);min-width:50px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#9db5d8;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.date-btn:hover{background:#ffffff17;color:#c4d8f0;border-color:#ffffff40}.date-btn.today .date-label{color:var(--gold);font-weight:800}.date-btn.active{background:linear-gradient(160deg,#f5a62321,#f5a6230a);border-color:var(--gold-soft);color:var(--gold);box-shadow:0 0 20px var(--gold-glow);position:relative;overflow:hidden}.date-btn.active:before{content:"";position:absolute;top:0;left:10%;width:80%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);border-radius:0 0 2px 2px}.date-btn.active .date-dow{color:var(--gold)}.date-dow{font-size:11px;font-weight:700;text-transform:uppercase;color:inherit}.date-label{font-size:13px;font-weight:700;color:#c4d8f0}.date-btn.blocked{opacity:.28;cursor:not-allowed;background:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(255,255,255,.03) 4px,rgba(255,255,255,.03) 8px)}.date-btn.blocked:hover{background:repeating-linear-gradient(-45deg,transparent,transparent 4px,rgba(255,255,255,.03) 4px,rgba(255,255,255,.03) 8px);color:var(--ink-3)}.date-blocked-mark{font-size:9px;font-weight:800;color:var(--red);line-height:1;margin-top:1px}.date-btn.weekend .date-label{color:var(--red)}.date-btn.active.weekend .date-label{color:var(--gold)}.filter-bar{display:flex;gap:8px;flex-wrap:wrap}.seg-ctrl{display:flex;border-radius:var(--r1);overflow:hidden;border:1px solid rgba(255,255,255,.15);background:#ffffff0d}.seg{padding:6px 14px;font-size:12px;font-weight:700;color:#9db5d8;border-right:1px solid var(--border);transition:background .12s,color .12s}.seg:last-child{border-right:none}.seg:hover{color:#c4d8f0;background:var(--bg4)}.seg.active{background:var(--gold);color:#1a0d00}.grid-area{display:flex;flex:1;overflow:hidden;min-width:0}.schedule-wrap{flex:1;overflow:auto;background:var(--bg)}.schedule-grid{display:grid;grid-template-columns:64px repeat(var(--court-count, 1),minmax(90px,1fr));min-width:max-content;width:100%}.grid-corner{position:sticky;left:0;top:0;z-index:10;background:var(--bg2);border-right:1px solid var(--border);border-bottom:1px solid var(--border);height:56px;box-shadow:2px 2px 0 var(--border)}.court-header{position:sticky;top:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 6px;height:56px;background:var(--bg2);border-bottom:1px solid var(--border2);border-right:1px solid var(--border);text-align:center}.court-header-name{font-size:11px;font-weight:600;color:var(--ink-2);line-height:1.3}.court-header-price{font-size:11px;color:var(--gold);font-weight:700}.time-label{position:sticky;left:0;z-index:4;display:flex;align-items:center;justify-content:flex-end;padding:0 10px;height:52px;background:var(--bg2);border-right:1px solid var(--border2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;color:var(--ink-2);box-shadow:2px 0 0 var(--border)}.cell{height:52px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .14s var(--ease),box-shadow .14s;display:flex;align-items:center;justify-content:center;position:relative}.cell-open{background:var(--cell-open);cursor:pointer;border-right:1px solid var(--border);border-bottom:1px solid var(--border);border-left:2px solid rgba(79,143,255,.25);position:relative}.cell-open:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(79,143,255,.2),transparent);pointer-events:none}.cell-open:hover{background:#4f8fff1a;box-shadow:inset 0 0 0 1px #4f8fff59,inset 0 0 12px #4f8fff1a;z-index:1}.cell-open:after{content:"+";font-size:16px;font-weight:800;color:var(--blue);opacity:0;transition:opacity .14s}.cell-open:hover:after{opacity:.7}.cell-taken{background:var(--cell-taken);cursor:not-allowed;border-right:1px solid rgba(239,68,68,.15);border-bottom:1px solid rgba(239,68,68,.12)}.cell-taken:after{content:"🔒";font-size:13px;opacity:.55}.cell-cutoff{background:#ffffff0a;cursor:not-allowed;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.cell-cutoff:after{content:"⏱";font-size:14px;opacity:.75;color:#7a94b8}.cell-selected{background:linear-gradient(#f5a6231f,#f5a6230f) padding-box,linear-gradient(160deg,var(--gold),var(--gold2)) border-box!important;border:1.5px solid transparent!important;box-shadow:inset 0 0 14px #f5a62324,0 0 14px var(--gold-glow)!important;cursor:pointer;z-index:1}.cell-selected:after{content:"✓";font-size:14px;font-weight:800;color:var(--gold);opacity:1}.cell-conflict{background:#ef44441f!important;cursor:not-allowed}.cell-conflict:after{content:"✕";font-size:13px;font-weight:800;color:var(--red);opacity:.8}.cell-start-dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}.cell-price{display:block;font-size:10px;font-weight:700;margin-top:2px;line-height:1;pointer-events:none;color:#a8c4e8}.cell-selected .cell-price,.cell-taken .cell-price{display:none}.grid-loading{padding:16px;display:flex;flex-direction:column;gap:6px}.row-skeleton{height:52px;border-radius:var(--r2);background:linear-gradient(90deg,var(--bg3) 25%,rgba(255,255,255,.04) 50%,var(--bg3) 75%);background-size:600px 100%;animation:shimmer 1.4s infinite linear}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes successPop{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}@keyframes drawerUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.floorplan-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:8px;font:inherit;font-size:12px;font-weight:600;border:1px solid rgba(245,166,35,.2);background:#f5a6230f;color:var(--gold);cursor:pointer;white-space:nowrap;margin-left:auto;transition:all .15s}.floorplan-btn:hover{border-color:#f5a62366;background:#f5a6231a}.floorplan-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#06090fb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end}.floorplan-drawer{width:100%;max-height:82vh;background:#0b1120;border-top:1px solid rgba(245,166,35,.2);border-radius:20px 20px 0 0;display:flex;flex-direction:column;animation:drawerUp .28s cubic-bezier(.32,.72,0,1) both;overflow:hidden}.floorplan-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.floorplan-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--ink-1)}.floorplan-title svg{color:var(--gold)}.floorplan-close{background:none;border:none;color:var(--ink-3);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:6px}.floorplan-close:hover{color:var(--ink-1);background:#ffffff0f}.floorplan-body{overflow-y:auto;padding:16px 20px 24px}.floorplan-legend{display:flex;gap:14px;margin-top:12px;flex-wrap:wrap}.fp-leg{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-3)}.fp-leg span{width:12px;height:12px;border-radius:3px;display:inline-block;flex-shrink:0}.success-modal{text-align:center;animation:successPop .25s cubic-bezier(.34,1.56,.64,1) both}.success-modal-icon{font-size:44px;margin-bottom:10px}.success-modal-title{font-size:20px;font-weight:800;color:var(--gold);margin-bottom:18px;letter-spacing:-.01em}.success-modal-body{text-align:left;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:18px}.success-modal-actions{display:flex;flex-direction:column;gap:8px}@keyframes swipeHint{0%{transform:translate(0);opacity:.5}to{transform:translate(4px);opacity:1}}.booking-sidebar{width:265px;flex-shrink:0;border-left:1px solid var(--border);background:#0b1120f2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;overflow-y:auto;box-shadow:-4px 0 24px #0006}.sidebar-section{padding:16px;border-bottom:1px solid var(--border)}.sidebar-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);margin-bottom:12px}.booking-summary{display:flex;flex-direction:column}.summary-row{display:flex;justify-content:space-between;align-items:baseline;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}.summary-row:last-child{border-bottom:none}.summary-row span{color:var(--ink-3);font-weight:500}.summary-row strong{color:var(--ink-1);font-weight:700}.price-row strong{font-size:18px;font-weight:800;background:linear-gradient(135deg,var(--gold) 30%,#ffca6e 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 10px rgba(245,166,35,.5))}.hint-text{font-size:13px;color:var(--ink-3);line-height:1.65}.auth-confirmed{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--green-fg);padding:10px 12px;border-radius:var(--r2);background:var(--green-bg);border:1px solid rgba(16,185,129,.2)}.provider-tag{margin-left:auto;font-size:11px;padding:2px 8px;border-radius:99px;background:#10b98126;color:var(--green-fg);font-weight:700}.auth-buttons{display:flex;flex-direction:column;gap:8px}.auth-hint{font-size:12px;color:var(--ink-3);font-weight:600;margin-bottom:4px}.auth-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:var(--r2);border:1px solid var(--border2);font-size:13px;font-weight:700;color:var(--ink-1);background:var(--bg3);transition:background .12s,box-shadow .14s;box-shadow:var(--sh-sm)}.auth-btn:hover{background:var(--bg4);box-shadow:var(--sh-md)}.confirm-btn{margin:16px;padding:14px;border-radius:var(--r2);background:linear-gradient(135deg,#f5a623,#e8820c 60%,#c96a05);color:#1a0d00;font-size:14px;font-weight:800;letter-spacing:.02em;box-shadow:0 0 28px var(--gold-glow),0 4px 16px #0006,inset 0 1px #fff3;transition:transform .16s var(--ease),box-shadow .16s}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 44px #f5a6238c,0 6px 24px #00000080}.confirm-btn:active:not(:disabled){transform:translateY(0);transition-duration:80ms}.confirm-btn:disabled{opacity:.3;cursor:not-allowed;transform:none;box-shadow:none;background:var(--bg4);color:var(--ink-3)}.dismiss-btn{width:100%;padding:10px;border-radius:var(--r2);background:var(--bg3);border:1px solid var(--border2);font-size:13px;font-weight:700;color:var(--ink-2);transition:background .12s;margin-top:4px}.dismiss-btn:hover{background:var(--bg4)}.legend{display:flex;flex-direction:column;gap:8px;padding:16px;margin-top:auto;border-top:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-3);font-weight:500}.legend-dot{width:24px;height:16px;border-radius:4px;flex-shrink:0}.legend-dot.open{background:var(--cell-open);border:1px solid var(--border2)}.legend-dot.taken{background:var(--cell-taken);border:1px solid var(--border);position:relative}.legend-dot.taken:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:2px;background:var(--ink-4);border-radius:2px}.legend-dot.selected{background:var(--cell-selected);border:2px solid var(--gold)}.legend-dot.conflict{background:#ef44441f;border:1px solid rgba(239,68,68,.3)}@media (max-width: 900px){.booking-sidebar{width:220px}}@media (max-width: 700px){.grid-area{flex-direction:column}.booking-sidebar{width:100%;border-left:none;border-top:1px solid var(--border);box-shadow:0 -4px 20px #0006}}.dur-ctrl{display:flex;align-items:center;gap:6px}.dur-label{font-size:12px;font-weight:700;color:var(--ink-3);white-space:nowrap}.dur-ctrl .seg-ctrl{border:1px solid var(--border);background:var(--bg3);border-radius:var(--r1);overflow:hidden;display:flex}.form-fields{display:flex;flex-direction:column;gap:10px}.field-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}.phone-label{display:flex;flex-direction:column;gap:8px}.phone-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r2);background:var(--bg3);color:var(--ink-1);font-size:14px;font-weight:500;transition:border-color .14s,box-shadow .14s}.phone-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow);background:var(--bg4)}.phone-input.input-err{border-color:var(--red)}.input-err-msg{font-size:12px;color:var(--red);font-weight:600}.conflict-warn{margin-top:8px;padding:8px 12px;border-radius:var(--r1);background:var(--red-bg);color:var(--red);font-size:12px;font-weight:700}.confirm-card{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.confirm-card-icon{width:52px;height:52px;border-radius:50%;background:var(--green-bg);border:2px solid rgba(16,185,129,.3);display:grid;place-items:center;font-size:24px;font-weight:800;color:var(--green)}.list-view{flex:1;padding:20px 16px;overflow:auto;background:var(--bg)}.admin-metrics{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.metric-box{flex:1;min-width:120px;padding:16px 20px;border-radius:var(--r3);background:var(--bg2);border:1px solid var(--border);box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:6px}.metric-box span{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;font-weight:800}.metric-box strong{font-size:26px;font-weight:800;color:var(--ink-1)}.booking-table{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;background:var(--bg2);box-shadow:var(--sh-sm)}.table-head{display:grid;grid-template-columns:1.5fr 1.5fr .8fr .6fr .4fr;padding:11px 16px;background:var(--bg3);border-bottom:1px solid var(--border);font-size:11px;font-weight:800;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;gap:8px}.table-row{display:grid;grid-template-columns:1.5fr 1.5fr .8fr .6fr .4fr;padding:13px 16px;border-bottom:1px solid var(--border);font-size:13px;color:var(--ink-2);gap:8px;align-items:center;transition:background .1s}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--bg3)}.status-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:800}.status-tag.confirmed{background:var(--green-bg);color:var(--green-fg)}.status-tag.pending,.status-tag.pending_payment{background:var(--gold-bg);color:var(--gold)}.status-tag.cancelled{background:#ffffff0f;color:var(--ink-3)}.empty-msg{padding:56px;text-align:center;color:var(--ink-3);font-size:14px}.center-msg{padding:56px;display:flex;flex-direction:column;align-items:center;gap:8px}@media (max-width: 700px){.table-head,.table-row{grid-template-columns:1fr 1fr .7fr}.table-head span:nth-child(n+4),.table-row span:nth-child(n+4){display:none}}.admin-head,.admin-row{grid-template-columns:1.2fr 1.4fr .8fr .5fr .8fr!important}.admin-actions{display:flex;gap:6px}.action-btn{padding:4px 10px;border-radius:var(--r1);font-size:11px;font-weight:800;transition:background .12s,transform .12s}.confirm-action{background:var(--green-bg);color:var(--green-fg);border:1px solid rgba(16,185,129,.22)}.confirm-action:hover{background:#10b98133;transform:translateY(-1px)}.cancel-action{background:var(--red-bg);color:var(--red);border:1px solid rgba(239,68,68,.22)}.cancel-action:hover{background:#ef444433;transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060cd1;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:28px;width:340px;box-shadow:0 24px 64px #0009,0 0 0 1px #ffffff0d;position:relative}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:16px;color:var(--ink-3);cursor:pointer;padding:4px 8px;border-radius:6px}.modal-close:hover{background:var(--bg3);color:var(--ink-2)}.modal-title{font-size:18px;font-weight:800;color:var(--ink-1);margin-bottom:16px}.modal-err{background:var(--red-bg);color:var(--red);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;margin-bottom:12px;border:1px solid rgba(239,68,68,.2)}.modal-form{display:flex;flex-direction:column;gap:10px}.modal-input{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font:inherit;font-size:14px;color:var(--ink-1);background:var(--bg3);transition:border-color .14s,box-shadow .14s}.modal-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow);background:var(--bg4)}.modal-submit{padding:11px;border-radius:10px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a0d00;font:inherit;font-size:14px;font-weight:800;border:none;cursor:pointer;box-shadow:0 0 20px var(--gold-glow);transition:filter .12s,box-shadow .12s}.modal-submit:hover{filter:brightness(1.08);box-shadow:0 0 30px #f5a62380}.modal-submit:disabled{opacity:.4;cursor:not-allowed}.modal-switch{margin-top:14px;font-size:13px;font-weight:600;color:var(--gold);background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:none;opacity:.85;transition:opacity .15s}.modal-switch:hover{opacity:1;text-decoration:underline}.auth-btn-top{padding:6px 14px;border-radius:8px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a0d00;font:inherit;font-size:13px;font-weight:700;border:none;cursor:pointer;box-shadow:0 0 14px var(--gold-glow);transition:filter .12s;white-space:nowrap;flex-shrink:0}.auth-btn-top:hover{filter:brightness(1.1)}@media (max-width: 640px){.auth-btn-top{padding:5px 10px;font-size:12px}}.notice-bar{padding:7px 20px;font-size:12px;font-weight:500;background:#f5a6230f;color:#c9a84c;border-bottom:1px solid rgba(245,166,35,.12);border-top:1px solid rgba(245,166,35,.08);display:flex;align-items:center;gap:8px;flex-shrink:0;letter-spacing:.01em;position:sticky;top:94px;z-index:198;-webkit-backdrop-filter:blur(12px) saturate(1.6);backdrop-filter:blur(12px) saturate(1.6)}.bklist{display:flex;flex-direction:column;gap:10px;padding:4px 0}.bk-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;box-shadow:var(--sh-sm);transition:box-shadow .15s,border-color .15s}.bk-card:hover{box-shadow:var(--sh-md);border-color:var(--border2)}.bk-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.bk-venue{font-size:11px;font-weight:700;color:var(--ink-4);text-transform:uppercase;letter-spacing:.07em}.bk-court{font-size:15px;font-weight:700;color:var(--ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bk-time{font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:4px}.bk-sep{color:var(--border2)}.bk-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.bk-price{font-size:17px;font-weight:800;color:var(--gold)}.bk-cancel{font-size:11px;margin-top:2px}@media (max-width: 480px){.bk-card{flex-direction:column;align-items:flex-start;gap:10px}.bk-meta{flex-direction:row;align-items:center;width:100%;justify-content:space-between}.topbar-right{gap:4px}}.preconfirm-modal{width:400px;max-width:calc(100vw - 32px);padding:0;overflow:hidden;background:var(--bg2);border-radius:20px;border:1px solid var(--border2);box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a}.preconfirm-header{padding:22px 24px 16px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#f5a6231a,#f5a6230a)}.preconfirm-title{font-size:17px;font-weight:800;color:var(--ink-1);margin-bottom:4px}.preconfirm-sub{font-size:12px;color:var(--ink-3)}.preconfirm-body{padding:16px 24px;display:flex;flex-direction:column;gap:11px;background:var(--bg2)}.preconfirm-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.preconfirm-row span{color:var(--ink-3)}.preconfirm-row strong{color:var(--ink-1);font-weight:700}.preconfirm-price{padding-top:12px;margin-top:4px;border-top:1px solid var(--border);font-size:16px}.preconfirm-price span{color:var(--ink-3);font-weight:600}.preconfirm-price strong{font-size:22px;font-weight:800;background:linear-gradient(135deg,var(--gold) 30%,#ffca6e 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 12px rgba(245,166,35,.55))}.preconfirm-actions{padding:0 24px 22px;display:flex;flex-direction:column;gap:8px;background:var(--bg2)}.table-total-row{display:grid;grid-template-columns:var(--booking-cols, 2fr 2fr 1fr 1fr auto);gap:8px;align-items:center;padding:10px 16px;border-top:2px solid var(--border);background:var(--bg3);border-radius:0 0 12px 12px}.total-amount{font-weight:800;font-size:15px;color:var(--gold)}.mobile-book-bar{display:none}@media (max-width: 768px){.mobile-book-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;position:fixed;bottom:0;left:0;right:0;z-index:300;padding:12px 16px 16px;background:#06090f73;-webkit-backdrop-filter:blur(40px) saturate(2.5) brightness(.9);backdrop-filter:blur(40px) saturate(2.5) brightness(.9);border-top:1px solid rgba(245,166,35,.22);box-shadow:0 -4px 32px #00000080}.mobile-book-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.mobile-book-court{font-size:13px;font-weight:700;color:var(--ink-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-book-time{font-size:11px;color:var(--ink-3)}.mobile-book-btn{flex-shrink:0;padding:12px 20px;border-radius:12px;border:none;cursor:pointer;background:linear-gradient(135deg,#f5a623,#e8820c);color:#1a0d00;font-size:14px;font-weight:800;font-family:inherit;box-shadow:0 0 24px #f5a62373;transition:opacity .15s,transform .1s;display:flex;align-items:center;gap:8px}.mobile-book-btn:active{transform:scale(.97)}.mobile-book-btn:disabled{opacity:.5;cursor:not-allowed}.book-view{padding-bottom:80px}.booking-sidebar{display:none}}.site-footer{margin-top:0;flex-shrink:0;position:relative;background:#06090fd9;-webkit-backdrop-filter:blur(24px) saturate(1.6);backdrop-filter:blur(24px) saturate(1.6);border-top:1px solid rgba(245,166,35,.12)}.site-footer:before{content:"";position:absolute;top:0;left:0;right:100%;height:1px;background:linear-gradient(to right,rgba(245,166,35,.5),rgba(79,143,255,.3),transparent);animation:footerLine 3s ease forwards}@keyframes footerLine{to{right:0}}.footer-inner{position:relative;max-width:1200px;margin:0 auto;padding:22px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}.footer-brand{display:flex;flex-direction:column;gap:4px}.footer-brand-name{font-family:Racing Sans One,sans-serif;font-size:17px;font-weight:400;letter-spacing:.02em;background:linear-gradient(90deg,#f5a623,#e8c06a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-copy{font-size:11px;color:#3f5278;margin-top:2px}.footer-contact{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.footer-label{font-size:10px;font-weight:800;color:#3f5278;text-transform:uppercase;letter-spacing:.12em}.footer-links{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}.footer-link{font-size:12px;color:var(--ink-2);text-decoration:none;display:flex;align-items:center;gap:6px;padding:5px 11px;border-radius:8px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;transition:color .15s,border-color .15s,background .15s;white-space:nowrap}.footer-link svg{opacity:.6;flex-shrink:0}.footer-link:hover{color:var(--gold);border-color:#f5a62333;background:#f5a6230d}.footer-link:hover svg{opacity:1}@media (max-width: 640px){.footer-inner{flex-direction:column;gap:16px}.footer-contact{align-items:flex-start}.footer-links{justify-content:flex-start}}.cookie-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:600;width:calc(100% - 32px);max-width:640px;background:#0b1120eb;-webkit-backdrop-filter:blur(28px) saturate(1.8);backdrop-filter:blur(28px) saturate(1.8);border:1px solid rgba(245,166,35,.18);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:0 8px 40px #0009,0 0 0 1px #ffffff0a}.cookie-text{font-size:12.5px;line-height:1.6;flex:1;min-width:180px;color:var(--ink-2)}.cookie-link{color:var(--gold);text-decoration:none;background:none;border:none;cursor:pointer;font:inherit;font-size:12.5px;padding:0;border-bottom:1px solid rgba(245,166,35,.4)}.cookie-actions{display:flex;gap:8px;flex-shrink:0}.cookie-btn{padding:8px 18px;border-radius:10px;font:inherit;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .15s}.cookie-btn.accept{background:linear-gradient(135deg,#f5a623,#e8820c);color:#1a0d00;box-shadow:0 0 16px #f5a62359}.cookie-btn.accept:hover{box-shadow:0 0 24px #f5a6238c;filter:brightness(1.08)}.cookie-btn.decline{background:#ffffff0d;color:var(--ink-3);border:1px solid rgba(255,255,255,.1)}.cookie-btn.decline:hover{background:#ffffff1a;color:var(--ink-2)}@media (max-width: 480px){.cookie-banner{bottom:12px;padding:14px 16px;border-radius:14px}.cookie-actions{width:100%}.cookie-btn{flex:1;text-align:center}}.venue-tabs{display:flex;flex-direction:row;gap:8px;padding:8px 16px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:nowrap;align-items:center;flex-shrink:0}.venue-tab{flex-shrink:0;padding:6px 18px;border-radius:20px;border:1px solid rgba(255,255,255,.18);background:#ffffff0d;color:#9db5d8;font:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.venue-tab:hover{color:#c4d8f0;border-color:#ffffff47;background:#ffffff17}.venue-tab.active{color:var(--gold);background:linear-gradient(var(--bg),var(--bg)) padding-box,linear-gradient(135deg,var(--blue),var(--gold)) border-box;border:1.5px solid transparent;box-shadow:0 0 16px var(--gold-glow)}.amenities-bar{display:flex;align-items:center;gap:0;padding:0 12px;background:transparent;border-bottom:1px solid rgba(255,255,255,.05);position:relative;overflow-x:auto;scrollbar-width:none}.amenities-bar::-webkit-scrollbar{display:none}.amenity-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 8px;border:none;border-right:1px solid rgba(255,255,255,.05);background:transparent;font-size:11px;font-weight:500;font-family:inherit;cursor:pointer;color:var(--gold);letter-spacing:.01em;white-space:nowrap;transition:background .15s}.amenity-chip:first-child{border-left:1px solid rgba(255,255,255,.05)}.amenity-chip svg{opacity:.8;flex-shrink:0;stroke:currentColor}.amenity-chip:active{background:#f5a62314}.amenity-popover{position:fixed;z-index:501;background:#0f1829fa;-webkit-backdrop-filter:blur(20px) saturate(1.8);backdrop-filter:blur(20px) saturate(1.8);border:1px solid rgba(245,166,35,.2);border-radius:14px;padding:16px 20px 14px;box-shadow:0 8px 40px #0009;max-width:300px;min-width:180px}.amenity-popover-icon{font-size:24px;margin-bottom:8px;color:var(--gold)}.amenity-popover-title{font-weight:700;font-size:14px;color:var(--gold);margin-bottom:6px;letter-spacing:.01em}.amenity-popover-detail{font-size:12.5px;color:var(--ink-2);line-height:1.7}.amenity-popover-close{position:absolute;top:10px;right:12px;background:none;border:none;font-size:15px;cursor:pointer;color:var(--ink-3);opacity:.6}.amenity-popover-close:hover{opacity:1}.ss-phone-input.PhoneInput{display:flex;align-items:center;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--bg3);transition:border-color .15s}.ss-phone-input.PhoneInput:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow)}.ss-phone-input .PhoneInputCountry{padding:0 8px 0 12px;border-right:1px solid var(--border);background:var(--bg4)}.ss-phone-input .PhoneInputCountrySelect{border:none;background:transparent;font-size:13px;cursor:pointer;outline:none;color:var(--ink-2)}.ss-phone-input .PhoneInputInput{flex:1;border:none;outline:none;padding:10px 12px;font-size:14px;font-family:inherit;background:transparent;color:var(--ink-1)}.modal-input.ss-phone-input{border-radius:10px;width:100%;margin-bottom:0}.modal-input.ss-phone-input .PhoneInputInput{padding:12px}.phone-input.ss-phone-input{border-radius:8px;width:100%}.phone-input.ss-phone-input.input-err{border-color:var(--red)}
