:root{--cyclone-brand:#d6001c;--cyclone-brand-hover:#c4202a;--cyclone-text-on-brand:#fff;--default-brand:#000;--default-brand-hover:#333;--default-text-on-brand:#fff;--tennis-danger:#e53e3e;--tennis-danger-hover:#c53030;--tennis-danger-text:#fff;--primary:var(--default-brand);--primary-hover:var(--default-brand-hover);--text-on-primary:var(--default-text-on-brand);--bg-color:#f7f7f9;--surface:#fff;--text-main:#111;--text-muted:#666;--border:#eaeaee;--bg-muted:#f9f9f9;--bg-hover:#0000000d;--overlay-bg:#00000080;--surface-frosted:#ffffffb3;--text-disabled:#999;--bg-disabled:#eee;--border-light:#eee;--success:#16a34a;--success-text:#fff;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,sans-serif;font-weight:400;line-height:1.5}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-color:#000;--surface:#1a1a1a;--text-main:#fff;--text-muted:#aaa;--border:#333;--bg-muted:#2c2c2e;--bg-disabled:#3a3a3c;--text-disabled:#666;--border-light:#2c2c2e;--bg-hover:#ffffff14;--overlay-bg:#000000bf;--surface-frosted:#1a1a1ad9;--default-brand:#fff;--default-brand-hover:#e0e0e0;--default-text-on-brand:#000;--tennis-danger:#d32f2f;--tennis-danger-hover:#b71c1c;--tennis-danger-text:#fff}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}img{-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none;-webkit-user-select:none;user-select:none;pointer-events:none}body{background-color:var(--bg-color);color:var(--text-main)}body.theme-cyclone{--primary:var(--cyclone-brand);--primary-hover:var(--cyclone-brand-hover);--text-on-primary:var(--cyclone-text-on-brand)}.button-outline{border:1px solid var(--primary);color:var(--text-main);cursor:pointer;letter-spacing:.5px;text-transform:uppercase;background:0 0;border-radius:4px;padding:.5rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s}@media (hover:hover){.button-outline:hover{background:var(--primary);color:var(--text-on-primary)}}.btn-view{background:var(--primary);color:var(--text-on-primary)}@media (hover:hover){.btn-view:hover{background:var(--primary-hover)}}.spot-ring-style{background-color:var(--text-main);color:var(--surface);border:2px solid var(--spot-gap-color,var(--bg-muted));box-shadow:0 0 0 2px var(--text-main)}[data-sonner-toast] [data-action]{background-color:var(--primary)!important;color:var(--text-on-primary)!important;border-radius:4px!important;font-family:inherit!important;font-weight:600!important;transition:background-color .2s!important}@media (hover:hover){[data-sonner-toast] [data-action]:hover{background-color:var(--primary-hover)!important}}[draggable=true]{touch-action:none}button,a,input[type=button],input[type=submit],.clickable,.btn,.schedule-toggle-card,.spot-circle{touch-action:manipulation}@media (width<=639px){.ios-underlay{filter:brightness(.6)!important;transform:translate(-15%)!important}.ios-underlay-capable{transition:transform .45s cubic-bezier(.32,.72,0,1),filter .45s cubic-bezier(.32,.72,0,1)}@keyframes iosSlideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes iosSlideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}}.btn{cursor:pointer;letter-spacing:.5px;text-transform:uppercase;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1.5rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn:disabled{cursor:not-allowed}.btn-outline{border:1px solid var(--primary);color:var(--text-main);background:0 0}@media (hover:hover){.btn-outline:not(:disabled):hover{background:var(--primary);color:var(--text-on-primary)}}.btn-primary{background:var(--primary);color:var(--text-on-primary);border:1px solid var(--primary)}@media (hover:hover){.btn-primary:not(:disabled):hover{background:var(--primary-hover);border-color:var(--primary-hover)}}.btn-ghost{color:var(--text-main);background:0 0;border:1px solid #0000}@media (hover:hover){.btn-ghost:not(:disabled):hover{background:var(--bg-hover)}}.btn-spinner{border:2px solid #0000001a;border-top-color:currentColor;border-radius:50%;width:1rem;height:1rem;animation:.8s linear infinite btn-spin;display:inline-block}.btn-primary .btn-spinner{border:2px solid #ffffff4d;border-top-color:var(--text-on-primary)}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-loading{opacity:.8;pointer-events:none}.btn-outline:disabled,.btn-primary:disabled{background-color:var(--bg-disabled);color:var(--text-disabled);border-color:var(--bg-disabled)}.btn-ghost:disabled{opacity:.5}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.modal-overlay{z-index:1000;background-color:#0000;flex-direction:column;animation:none;display:flex;position:fixed;inset:0}.modal-container{background-color:var(--surface);flex-direction:column;width:100%;height:100%;animation:.45s cubic-bezier(.32,.72,0,1) iosSlideInRight;display:flex;overflow:hidden}.modal-container.closing{animation:.45s cubic-bezier(.32,.72,0,1) forwards iosSlideOutRight}@media (width>=640px){.modal-overlay{background-color:var(--overlay-bg);justify-content:center;align-items:center;padding:2rem;animation:.3s ease-out modalFadeIn}.modal-overlay.closing{animation:.3s ease-out forwards modalFadeOut}.modal-container{border:none;border-radius:1rem;width:100%;max-width:37.5rem;height:auto;max-height:90vh;animation:.3s ease-out modalSlideUp;box-shadow:0 .5rem 2.5rem #0009}.modal-container.closing{animation:.3s ease-out forwards modalSlideDown}}.class-details-header{background-color:var(--cyclone-brand);color:var(--text-on-primary);flex-direction:column;padding:1rem 1.5rem;display:flex;position:relative}.class-details-close-btn{cursor:pointer;z-index:10;background:0 0;border:none;padding:0;position:absolute;top:1rem;right:1rem}.class-details-header-content h2{margin:0 0 .5rem;padding-right:2rem;font-size:1.5rem;font-weight:700}.class-details-header-content .datetime{margin:.25rem 0;font-size:1rem;font-weight:600}.class-details-header-content .meta{margin:.25rem 0;font-size:1rem;font-weight:400}.class-details-content{flex:1;padding:1rem 1.5rem;overflow-y:auto}.class-details-section{border-bottom:1px solid var(--border-light);margin-bottom:1rem;padding-bottom:1rem}.class-details-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.class-details-section h3{color:var(--text-main);margin-bottom:.5rem;font-size:1rem;font-weight:700}.class-details-section p{color:var(--text-muted);white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.5}.class-details-instructor{align-items:center;gap:1.5rem;display:flex}.class-details-instructor-avatar{object-fit:cover;background-color:var(--bg-disabled);border-radius:50%;width:4.5rem;height:4.5rem}.class-details-instructor-name{color:var(--text-main);font-size:1.25rem;font-weight:700}.class-details-reserve-action{background-color:var(--surface);border-top:1px solid var(--border-light);margin-top:auto;padding:1.5rem}.class-details-mobile-nav{display:none}@media (width<=639px){.class-details-mobile-nav{align-items:center;margin-bottom:.5rem;display:flex}.class-details-mobile-nav .back-link{cursor:pointer;background:0 0;border:none;align-items:center;margin-left:-.5rem;padding:0;display:inline-flex}.class-details-close-btn{display:none}.class-details-header-content h2{padding-right:0}}.user-menu-container{align-items:center;display:inline-flex;position:relative}.user-menu-trigger{cursor:pointer;background:0 0;border:none;border-radius:50%;outline:none;justify-content:center;align-items:center;padding:0;transition:box-shadow .2s;display:flex}.user-menu-trigger:focus-visible{box-shadow:0 0 0 2px var(--primary)}@media (hover:hover){.user-menu-trigger:hover{box-shadow:0 0 0 2px var(--primary)}}.user-avatar{object-fit:cover;border-radius:50%;width:32px;height:32px;display:block}.fallback-avatar{background-color:var(--text-main);color:var(--surface);justify-content:center;align-items:center;font-size:.875rem;font-weight:600;display:flex}.user-menu-dropdown{background-color:var(--surface);border:1px solid var(--border);z-index:100;border-radius:8px;min-width:160px;animation:.15s ease-out forwards slideDown;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 4px 12px #0000001a}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{border-bottom:1px solid var(--border);padding:.75rem 1rem}.user-menu-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:700;overflow:hidden}.user-menu-item{text-align:left;width:100%;color:var(--text-main);cursor:pointer;background:0 0;border:none;padding:.75rem 1rem;font-size:.875rem;transition:background-color .2s;display:block}@media (hover:hover){.user-menu-item:hover{background-color:var(--bg-color)}}.home-page-wrapper{flex-direction:column;min-height:100vh;display:flex}.home-container{background:var(--surface);flex-grow:1;width:100%;max-width:50rem;margin:0 auto;padding:0 0 1rem}.calendar-header{background:var(--surface-frosted);-webkit-backdrop-filter:blur(12px);z-index:10;border-bottom:1px solid var(--border);width:100%;padding:1rem 0 0;position:sticky;top:0}.calendar-header-inner{max-width:50rem;margin:0 auto}@media (width>=640px){.calendar-header-top{padding:0 1.5rem 1rem}.calendar-days{padding:0 1.5rem}}.calendar-header-top{padding:0 1rem 1rem}.calendar-days{justify-content:space-between;align-items:center;padding:0 1rem;display:flex}.calendar-day{cursor:pointer;color:var(--text-muted);touch-action:manipulation;flex-direction:column;align-items:center;padding:.5rem 1rem;transition:color .2s;display:flex;position:relative}@media (hover:hover){.calendar-day:hover{color:var(--text-main)}}.calendar-day.active{color:var(--text-main)}.calendar-day .month-day{margin-bottom:.25rem;font-size:.875rem;font-weight:500}.calendar-day .weekday{text-transform:uppercase;font-size:1.125rem;font-weight:700}.btn-today{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;box-shadow:0 1px 2px #0000000d}@media (hover:hover){.btn-today:hover{border-color:var(--text-muted);background:var(--bg-muted)}}.class-list{flex-direction:column;padding:0 1.5rem;display:flex}.class-item{cursor:pointer;border-bottom:1px solid var(--border);grid-template:"time name name""img details button"/6rem 1fr auto;align-items:flex-start;gap:.2rem 1rem;padding:1rem 0;display:grid;position:relative}.class-item:last-child{border-bottom:none}@media (width>=640px){.home-page-wrapper.reserve-active>.calendar-header,.home-page-wrapper.reserve-active>.home-container{display:none}}.class-item.booked-class:before{content:"";background-color:var(--primary);width:4px;position:absolute;top:1rem;bottom:1rem;left:-1rem}.class-item button{grid-area:button;align-self:flex-end;padding-top:.75rem;padding-bottom:.75rem}.time-col{white-space:nowrap;grid-area:time;justify-content:flex-start;display:flex}.time-col .time{color:var(--text-main);font-family:Avenir Next,Montserrat,sans-serif;font-size:1.1rem;font-weight:700}.instructor-avatars{grid-area:img;align-items:flex-start;margin:.1rem 0 0;display:flex}.instructor-img{object-fit:cover;background-color:var(--bg-disabled);border:.125rem solid var(--surface);border-radius:50%;width:4.375rem;height:4.375rem;position:relative}.instructor-avatars.multiple .instructor-img{width:3.5rem;height:3.5rem;margin-left:-1.375rem}.instructor-avatars.multiple .instructor-img:first-child{z-index:1;margin-left:0}.instructor-avatars.multiple .instructor-img:nth-child(2){z-index:2;margin-top:1.375rem}.instructor-avatars.multiple .instructor-img:nth-child(3){z-index:3;margin-top:2.75rem}.instructor-names{flex-direction:column;display:flex}.details-col{flex-direction:column;grid-area:details;display:flex}.class-name{text-transform:uppercase;color:var(--text-main);text-decoration:underline;-webkit-text-decoration-color:var(--primary);text-decoration-color:var(--primary);text-underline-offset:4px;grid-area:name;margin-bottom:0;font-family:Avenir Next,Montserrat,sans-serif;font-size:1.15rem;font-weight:700;text-decoration-thickness:1px}.details-col .instructor-name{color:var(--text-main);margin-top:0;font-family:Inter,Roboto,sans-serif;font-size:.9rem}.details-col .class-type{color:var(--text-main);margin-top:.25rem;font-family:Inter,Roboto,sans-serif;font-size:.9rem}.details-col .duration{color:var(--text-muted);margin-top:.25rem;font-family:Inter,Roboto,sans-serif;font-size:.85rem;font-weight:300}.loading-state,.error-state,.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}@media (width<=639px){.calendar-days{padding:0 .5rem}.calendar-spacer{display:none}.calendar-day{padding:.5rem .25rem}.calendar-day .month-day{font-size:.75rem}.calendar-day .weekday{font-size:.9rem}.calendar-day .month-text,.hide-on-mobile{display:none}.class-item{grid-template-columns:4.5rem 1fr auto;gap:.2rem 1rem;padding:.75rem 0}.time-col .time{font-size:.95rem}.class-name{font-size:1rem}.details-col .instructor-name,.details-col .class-type{font-size:.8rem}.details-col .duration{font-size:.75rem}.instructor-img{width:4rem;height:4rem}.instructor-avatars.multiple .instructor-img{width:2.75rem;height:2.75rem;margin-left:-1rem}.instructor-avatars.multiple .instructor-img:nth-child(2){margin-top:1rem}.class-item button{padding:.5rem 1rem;font-size:.85rem}}@media (width>=576px) and (width<=639px){.calendar-days{padding:0 1.25rem}}.carousel-track.is-animating{transition:transform .3s ease-out}.carousel-track.is-animating.is-shrinking{transition:transform .3s ease-out,min-height .35s ease-out}.carousel-track.is-swiping{transition:none}@media (width>=640px){.carousel-track{transform:none!important}.carousel-track.is-animating.is-shrinking{transition:min-height .35s ease-out!important}.carousel-track>main{opacity:0;pointer-events:none;z-index:1;transition:opacity .15s ease-out,transform .4s cubic-bezier(.4,0,.2,1);position:absolute!important;left:0!important}.carousel-track>main.active{opacity:1;pointer-events:auto;z-index:2;transition:opacity .2s ease-in-out,transform .4s cubic-bezier(.1,.4,.9,.4);transform:translate(0)}.carousel-track.slide-right>main:not(.active){transform:translate(-5px)}.carousel-track.slide-right>main.active{animation:.3s cubic-bezier(.4,0,.2,1) forwards slideInRight}.carousel-track.slide-left>main:not(.active){transform:translate(5px)}.carousel-track.slide-left>main.active{animation:.3s cubic-bezier(.4,0,.2,1) forwards slideInLeft}@keyframes slideInRight{0%{transform:translate(45px)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-45px)}to{transform:translate(0)}}}.segmented-control{background-color:var(--bg-disabled);border-radius:8px;padding:4px;display:flex;position:relative}.segmented-control-indicator{background-color:var(--primary);z-index:1;border-radius:6px;transition:transform .3s cubic-bezier(.4,0,.2,1);position:absolute;top:4px;bottom:4px;left:4px;box-shadow:0 2px 4px #0000001a}.segmented-control-btn{cursor:pointer;color:var(--text-main);z-index:2;background:0 0;border:none;border-radius:6px;flex:1;padding:.75rem;font-size:.875rem;font-weight:600;transition:color .3s;position:relative}.segmented-control-btn.active{color:var(--text-on-primary)}.segmented-control-btn:disabled{color:var(--text-disabled);cursor:not-allowed}@keyframes slideUpBottomSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDownBottomSheet{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes fadeInBottomSheet{0%{opacity:0}to{opacity:1}}@keyframes fadeOutBottomSheet{0%{opacity:1}to{opacity:0}}.bottom-sheet-overlay{background-color:var(--overlay-bg);z-index:1000;flex-direction:column;justify-content:flex-end;animation:.3s ease-out fadeInBottomSheet;display:flex;position:fixed;inset:0}.modal-overlay.bottom-sheet-overlay.closing{animation:.3s ease-out forwards fadeOutBottomSheet}.bottom-sheet-container{background-color:var(--surface);border-radius:1rem 1rem 0 0;flex-direction:column;width:100%;height:auto;padding:1.5rem;animation:.3s ease-out slideUpBottomSheet;display:flex;box-shadow:0 -4px 20px #0000001a}.modal-container.bottom-sheet-container.closing{animation:.3s ease-out forwards slideDownBottomSheet}.bottom-sheet-header h2{color:var(--text-main);text-transform:uppercase;margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.bottom-sheet-header .datetime{color:var(--text-main);margin:0 0 .25rem;font-size:1rem;font-weight:700}.bottom-sheet-header .meta{color:var(--text-muted);margin:0 0 .25rem;font-size:.875rem}.bottom-sheet-body{border-top:1px solid var(--border-light);margin-top:1.5rem;padding-top:1.5rem}.bottom-sheet-footer{margin-top:auto}.bottom-sheet-footer .button-outline:disabled{background-color:var(--bg-disabled);color:var(--text-disabled);border:1px solid var(--border-light);cursor:not-allowed}@keyframes slideUpBottomSheetDesktop{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDownBottomSheetDesktop{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}@media (width>=640px){.bottom-sheet-overlay{justify-content:center;align-items:center;padding:2rem}.bottom-sheet-container{border-radius:1rem;max-width:500px;height:auto;animation:.3s ease-out slideUpBottomSheetDesktop}.modal-container.bottom-sheet-container.closing{animation:.3s ease-out forwards slideDownBottomSheetDesktop}}.spot-info-row{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.spot-info{align-items:center;gap:1rem;display:flex}.spot-number-circle{--spot-gap-color:var(--surface);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:700;display:flex}.spot-details{flex-direction:column;display:flex}.spot-label{color:var(--text-main);font-size:1rem;font-weight:700}.spot-type{color:var(--text-muted);font-size:.875rem}.change-spot-btn{color:var(--text-main);cursor:pointer;background:0 0;border:none;align-items:center;padding:0;font-size:1rem;font-weight:600;display:flex}@media (hover:hover){.change-spot-btn:hover{text-decoration:underline}}.spot-modal-reserve-for-section{margin-bottom:2rem}.spot-modal-reserve-for-label{color:var(--text-main);margin-bottom:.75rem;font-size:1rem;font-weight:700;display:block}.reservation-page-wrapper{background:var(--surface);z-index:1000;flex-direction:column;min-height:100vh;display:flex;position:relative}.reservation-top{width:100%;max-width:50rem;margin:0 auto;padding:1rem 1.5rem 0}.reservation-nav-row{justify-content:space-between;align-items:center;height:40px;margin-bottom:.5rem;display:flex}.back-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;padding:0;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s;display:inline-flex}@media (hover:hover){.back-link:hover{color:var(--text-main)}}.class-info-block h2{color:var(--text-main);margin-bottom:.25rem;font-size:1.25rem;font-weight:700}.class-info-block .date-time{color:var(--text-main);margin-bottom:.5rem;font-size:.875rem;font-weight:600}.class-info-block .meta{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem}.view-details{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.875rem;text-decoration:underline}.layout-section{background-color:var(--bg-muted);border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-grow:1;justify-content:center;align-items:center;width:100%;margin-top:2rem;padding:2rem 0;display:flex;container-type:size}.legend{flex-direction:column;gap:.75rem;display:flex;position:absolute;top:0;right:0}.legend .legend-title{margin-bottom:.25rem;font-size:.875rem;font-weight:700}.legend-item{color:var(--text-main);align-items:center;gap:.75rem;font-size:.875rem;display:flex}.legend-circle{border:1px solid var(--border);border-radius:50%;width:20px;height:20px}.legend-circle.available{background-color:var(--surface);border-color:var(--text-disabled)}.legend-circle.unavailable{background-color:var(--bg-disabled);border-color:var(--border);background-image:repeating-linear-gradient(45deg, transparent, transparent 2px, var(--border-light) 2px, var(--border-light) 4px)}.legend-circle.selected{background-color:var(--text-main);border-color:var(--text-main)}.spot-map{width:100%;max-width:calc(var(--grid-cols) * 55px);aspect-ratio:var(--aspect-ratio);margin:0 auto;position:relative;container-type:inline-size}.spot-circle{left:var(--orig-left);top:var(--orig-top);width:clamp(20px, calc(100cqi / var(--grid-cols) * .8), 44px);height:clamp(20px, calc(100cqi / var(--grid-cols) * .8), 44px);font-size:clamp(.7rem, calc(100cqi / var(--grid-cols) * .35), 1rem);border-radius:50%;justify-content:center;align-items:center;font-weight:500;transition:all .2s;display:flex;position:absolute;transform:translate(-50%,-50%)}.show-on-mobile{display:none}.mobile-cancel-container{background:var(--surface);width:100%;padding:1.5rem}@media (width<=639px){.reservation-page-wrapper{background:var(--surface);z-index:1000;width:100%;height:100dvh;animation:.45s cubic-bezier(.32,.72,0,1) iosSlideInRight;position:fixed;top:0;left:0;overflow:hidden auto}.reservation-page-wrapper.closing-page{animation:.45s cubic-bezier(.32,.72,0,1) forwards iosSlideOutRight}.reservation-top{padding:1rem 1rem 0}.back-link{font-size:1.25rem;font-weight:600}.reservation-nav-row{margin-bottom:0}.layout-section{min-height:0;margin-top:1rem;padding:.75rem;container-type:size}.hide-on-mobile{display:none!important}.show-on-mobile{display:block!important}.spot-map{aspect-ratio:var(--aspect-ratio-mobile);width:min(calc(var(--grid-cols-mobile) * 55px), 100cqw, calc(100cqh * var(--aspect-ratio-mobile-val)));max-width:none}.spot-circle{left:var(--rot-left);top:var(--rot-top);width:clamp(20px, calc(100cqi / var(--grid-cols-mobile) * .8), 44px);height:clamp(20px, calc(100cqi / var(--grid-cols-mobile) * .8), 44px);font-size:clamp(.7rem, calc(100cqi / var(--grid-cols-mobile) * .35), 1rem)}}.spot-circle.available{background-color:var(--surface);border:1px solid var(--text-muted);color:var(--text-main);cursor:pointer}@media (hover:hover){.spot-circle.available:hover{border-color:var(--text-main);box-shadow:0 0 0 2px #0000001a}}.spot-circle.unavailable{background-color:var(--bg-disabled);border:1px solid var(--border);color:var(--text-disabled);cursor:not-allowed;background-image:repeating-linear-gradient(45deg, transparent, transparent 3px, var(--border-light) 3px, var(--border-light) 6px)}.spot-circle.booked-by-me{cursor:not-allowed}.spot-circle.booked-by-guest{background-color:var(--text-main);border:1px solid var(--text-main);color:var(--surface);cursor:not-allowed}.spot-circle.booked-by-other{background-color:var(--bg-disabled);border:1px solid var(--border);color:var(--text-disabled);cursor:not-allowed;background-image:repeating-linear-gradient(45deg, transparent, transparent 3px, var(--border-light) 3px, var(--border-light) 6px)}.loading-overlay{min-height:50vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.125rem;display:flex}.cancel-schedule-btn{background-color:var(--tennis-danger)!important;border-color:var(--tennis-danger)!important;color:var(--tennis-danger-text)!important}@media (hover:hover){.cancel-schedule-btn:hover{background-color:var(--tennis-danger-hover)!important;border-color:var(--tennis-danger-hover)!important;color:var(--tennis-danger-text)!important}}.fullscreen-modal{border-radius:0;flex-direction:column;width:100%;max-width:100vw;height:100%;max-height:100vh;display:flex;overflow:hidden}.schedule-preview-modal-header{border-bottom:1px solid var(--border);background-color:var(--surface);flex-wrap:wrap;order:1;justify-content:flex-start;align-items:center;padding:1rem;display:flex}.header-segmented-control{order:1;min-width:250px;margin-right:1rem}.header-date{color:var(--text-main);order:2;margin-right:auto;font-size:1.1rem;font-weight:600}.header-close-btn{order:3}.schedule-preview-modal-header h2{margin:0}.schedule-preview-modal-content{background-color:var(--surface);flex:1;order:2;padding:0;overflow-y:auto}@media (width<=639px){.schedule-preview-modal-header{border-bottom:none;border-top:1px solid var(--border);order:3;margin-bottom:.25rem;padding:.5rem}.header-segmented-control{order:1;margin-right:auto}.header-close-btn{order:2;margin-right:.1rem}.header-date{text-align:center;order:3;width:100%;margin-top:.5rem;margin-right:0}}.schedule-table-container{width:100%;height:100%;overflow:auto}.schedule-table{border-collapse:collapse;table-layout:fixed;width:100%}.schedule-table th{color:#fff;border:1px solid var(--border);z-index:2;background-color:#00a2c7;padding:1rem .5rem;font-weight:700;position:sticky;top:0}.schedule-table td{border:1px solid var(--border);text-align:center;vertical-align:middle;height:80px;padding:.75rem .5rem}.schedule-table td.available{background-color:var(--surface)}.schedule-table td.booked{color:#08c}.cell-time{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem}.schedule-table td.booked .cell-time{color:inherit;opacity:.8}.cell-title{color:#00a2c7;font-size:.95rem;font-weight:700}.schedule-table td.booked .cell-title,.schedule-table td.scheduled .cell-time,.schedule-table td.scheduled .cell-title,.schedule-table td.pending .cell-time,.schedule-table td.pending .cell-title{color:inherit}.schedule-table td.scheduled .cell-time,.schedule-table td.pending .cell-time{opacity:.9}@keyframes slotPopBounce{0%{transform:scale(.9)}60%{transform:scale(1.05)}to{transform:scale(1)}}.schedule-table td.pending{transform-origin:50%;z-index:10;animation:.4s cubic-bezier(.175,.885,.32,1.275) forwards slotPopBounce;position:relative}.tennis-page-wrapper{flex-direction:column;min-height:100vh;display:flex}.tennis-header{background:var(--surface-frosted);-webkit-backdrop-filter:blur(12px);z-index:10;border-bottom:1px solid var(--border);width:100%;padding:1rem 0 0;position:sticky;top:0}.tennis-header-inner{max-width:50rem;margin:0 auto}.tennis-header-top{padding:0 1rem 1rem}@media (width>=640px){.tennis-header-top{padding:0 1.5rem 1rem}}.burlington-tennis-container{box-sizing:border-box;background:0 0;flex-direction:column;flex-grow:1;width:100%;max-width:50rem;margin:0 auto;padding:1.5rem 1rem 2rem;display:flex}.tennis-tile{background:var(--surface);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.burlington-tennis-content-wrapper{flex-direction:column;flex:1;justify-content:center;display:flex}.burlington-tennis-loading-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}.burlington-tennis-actions{flex-direction:column;gap:1.5rem;display:flex}.burlington-tennis-header{justify-content:space-between;align-items:center;display:flex}.desktop-date{display:inline}.mobile-date{display:none}@media (width<=639px){.schedule-toggle-card{padding:1rem}.desktop-date{display:none}.mobile-date{display:inline}}.schedule-toggle-card{background:var(--tennis-danger);color:var(--tennis-danger-text);border:1px solid var(--tennis-danger);cursor:pointer;text-align:center;box-shadow:none;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:1.5rem;transition:all .2s;display:flex}.schedule-toggle-card.scheduled{background:var(--success);color:var(--success-text);border:1px solid var(--success);box-shadow:0 4px 12px #16a34a4d}.schedule-toggle-card.loading{opacity:.5;pointer-events:none;cursor:wait}.schedule-toggle-title{margin-bottom:.5rem;font-size:1.5rem}.schedule-toggle-date{opacity:.9;margin:.25rem 0;font-size:1.1rem;font-weight:600}.schedule-toggle-desc{opacity:.8;margin:0;font-size:.9rem}.preferred-times-header,.court-priority-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.court-priority-header{margin-bottom:.5rem}.configure-times-btn,.reset-priority-btn{padding:.4rem .75rem;font-size:.9rem}.drag-help-text{color:gray;margin-bottom:1.5rem;font-size:.9rem;display:block}.drag-list{padding:0;list-style:none}.drag-list-item{border:1px solid var(--border);background:var(--surface);color:var(--text-main);border-radius:8px;align-items:center;gap:1rem;margin-bottom:.5rem;padding:1rem;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000000d}.drag-list-item.dragging{opacity:.5;transform:scale(1.02);box-shadow:0 10px 20px #0000001a}.drag-handle{color:var(--text-muted);-webkit-user-select:none;user-select:none;cursor:grab;touch-action:none;padding:.5rem}.how-priority-works-card{background:var(--bg-muted);border:1px solid var(--border-light);border-radius:8px;margin-top:2rem;padding:1rem}.how-priority-works-title{margin:0 0 .5rem}.how-priority-works-text{color:var(--text-muted);margin:0;font-size:.9rem}.config-container{background:0 0;flex-grow:1;width:100%;max-width:50rem;margin:0 auto;padding:1.5rem 1rem 2rem}.config-header{margin:0 0 1rem}.config-input-group{gap:.5rem;margin:1rem 0;display:flex}.config-input{border:1px solid var(--border);border-radius:4px;flex:1;padding:.5rem}.config-list{padding:0;list-style:none}.config-list-item{border-bottom:1px solid var(--border);justify-content:space-between;padding:.5rem;display:flex}.config-remove-btn{color:var(--tennis-danger);cursor:pointer;background:0 0;border:none}.settings-loading{text-align:center;color:var(--text-muted);padding:4rem 2rem}.settings-section{background:var(--surface);border-radius:8px;margin-bottom:1.5rem;padding:1.5rem}.settings-section-header{justify-content:space-between;align-items:center;display:flex}.settings-section-title{margin:0}.settings-action-btn{padding:.5rem 1rem;font-size:.875rem}.settings-description{color:var(--text-muted);margin-bottom:1rem;font-size:.875rem}.settings-empty-state{background:var(--card-bg);text-align:center;color:var(--text-muted);border-radius:8px;padding:1rem}.drag-list{margin:0;padding:0;list-style:none}.drag-list-item{background:var(--card-bg);border-radius:8px;align-items:center;gap:1rem;margin-bottom:.5rem;padding:1rem;display:flex}.drag-handle{cursor:grab;color:var(--text-muted);font-size:1.25rem}.settings-info-box{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:1.5rem;padding:1.5rem}.settings-info-title{margin:0 0 .5rem}.settings-info-text{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.5}.config-done-wrapper{gap:1rem;margin-top:2rem;padding-bottom:1rem;transition:padding-bottom .3s;display:flex}.config-done-wrapper.has-unsaved-changes{padding-bottom:4rem}.config-done-action-btn{flex:1;padding:1rem;font-size:1.125rem}.dnd-poly-drag-image{opacity:.5!important}.dnd-poly-drag-image.dnd-poly-snapback{transition-property:transform!important;transition-duration:.25s!important;transition-timing-function:ease-out!important}
